当前位置:首页 > 技术 > 正文内容

基于SSM与Vue的电脑评测平台设计与实现

访客 技术 2026年6月27日 1

系统概述

随着信息化管理的不断深入,个人用户对信息展示与交互平台的需求日益增长。基于Java技术栈的电脑评测系统在当前开发环境中已具备成熟的技术基础。本文阐述了一个以SSM(Spring、Spring MVC、MyBatis)为核心架构,结合Vue前端框架构建的B/S模式评测平台的设计与实现过程。系统通过分析用户对电脑设备评测、品牌分类及互动交流的实际需求,完成了从功能规划到数据库建模的完整开发流程。

该平台主要面向两类用户:管理员与普通用户。管理员拥有全面的后台管理权限,包括用户账户管理、电脑类型与分类维护、品牌信息配置、设备数据录入、评测内容审核、论坛模块监管以及系统参数设置等。普通用户则可进行个人信息管理、浏览和收藏电脑设备、发布与查看评测内容、参与社区讨论等操作,满足个性化使用需求。

系统采用前后端分离架构,后端基于Java语言,使用Spring作为核心容器,Spring MVC处理Web请求,MyBatis实现数据持久化;前端采用Vue.js结合HTML/CSS进行界面渲染。数据库选用MySQL 5.7及以上版本,确保数据存储的稳定性与高效性。项目构建工具为Maven,开发环境支持IntelliJ IDEA或Eclipse,服务器运行环境为Tomcat 7至10系列。

关键技术实现

跨域请求处理

由于前端与后端部署在不同域名或端口,需配置跨域资源共享(CORS)。通过自定义拦截器实现全局跨域支持,同时集成Token认证机制,保障接口安全。

package com.interceptor;

import com.alibaba.fastjson.JSONObject;
import com.annotation.IgnoreAuth;
import com.entity.EIException;
import com.entity.TokenEntity;
import com.service.TokenService;
import com.utils.R;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

@Component
public class AuthTokenInterceptor implements HandlerInterceptor {

    public static final String HEADER_TOKEN = "Token";

    @Autowired
    private TokenService tokenService;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
        // 设置跨域响应头
        String origin = request.getHeader("Origin");
        response.setHeader("Access-Control-Allow-Origin", origin);
        response.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS");
        response.setHeader("Access-Control-Allow-Headers", "Content-Type, Token, Authorization, X-Requested-With");
        response.setHeader("Access-Control-Allow-Credentials", "true");

        if ("OPTIONS".equalsIgnoreCase(request.getMethod())) {
            return true;
        }

        IgnoreAuth ignoreAuth = null;
        if (handler instanceof HandlerMethod) {
            ignoreAuth = ((HandlerMethod) handler).getMethodAnnotation(IgnoreAuth.class);
        }

        if (ignoreAuth != null) {
            return true;
        }

        String token = request.getHeader(HEADER_TOKEN);
        if (StringUtils.isBlank(token)) {
            sendAuthFailure(response);
            return false;
        }

        TokenEntity tokenInfo = tokenService.getTokenEntity(token);
        if (tokenInfo == null) {
            sendAuthFailure(response);
            return false;
        }

        request.getSession().setAttribute("userId", tokenInfo.getUserid());
        request.getSession().setAttribute("role", tokenInfo.getRole());
        request.getSession().setAttribute("tableName", tokenInfo.getTablename());
        request.getSession().setAttribute("username", tokenInfo.getUsername());

        return true;
    }

    private void sendAuthFailure(HttpServletResponse response) {
        response.setCharacterEncoding("UTF-8");
        response.setContentType("application/json;charset=utf-8");
        try (PrintWriter writer = response.getWriter()) {
            writer.write(JSONObject.toJSONString(R.error(401, "请先登录")));
            writer.flush();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

用户认证与会话管理

系统提供标准的注册、登录、登出及密码重置功能。用户身份通过生成唯一Token并存储于服务端进行验证,避免敏感信息暴露。

package com.controller;

import com.annotation.IgnoreAuth;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.TokenEntity;
import com.entity.UserEntity;
import com.service.TokenService;
import com.service.UserService;
import com.utils.MD5Util;
import com.utils.PageUtils;
import com.utils.R;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpServletRequest;
import java.util.Map;

@RestController
@RequestMapping("/api/user")
public class UserController {

    @Autowired
    private UserService userService;

    @Autowired
    private TokenService tokenService;

    // 用户登录
    @IgnoreAuth
    @PostMapping("/login")
    public R login(@RequestParam String username, @RequestParam String password, HttpServletRequest req) {
        UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
        if (user == null || !user.getPassword().equals(password)) {
            return R.error("用户名或密码错误");
        }
        String token = tokenService.generateToken(user.getId(), username, "users", user.getRole());
        return R.ok().put("token", token);
    }

    // 用户注册
    @IgnoreAuth
    @PostMapping("/register")
    public R register(@RequestBody UserEntity newUser) {
        if (userService.selectOne(new EntityWrapper<UserEntity>().eq("username", newUser.getUsername())) != null) {
            return R.error("该用户名已被使用");
        }
        userService.insert(newUser);
        return R.ok("注册成功");
    }

    // 获取当前登录用户信息
    @GetMapping("/profile")
    public R getProfile(HttpServletRequest request) {
        Long userId = (Long) request.getSession().getAttribute("userId");
        if (userId == null) {
            return R.error(401, "未登录");
        }
        UserEntity user = userService.selectById(userId);
        return R.ok().put("data", user);
    }

    // 修改用户信息
    @PostMapping("/update")
    public R updateProfile(@RequestBody UserEntity user) {
        userService.updateById(user);
        return R.ok("更新成功");
    }

    // 用户登出
    @GetMapping("/logout")
    public R logout(HttpServletRequest request) {
        request.getSession().invalidate();
        return R.ok("已安全退出");
    }

    // 密码重置(简易版)
    @IgnoreAuth
    @GetMapping("/reset")
    public R resetPassword(String username) {
        UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
        if (user == null) {
            return R.error("用户不存在");
        }
        user.setPassword("123456"); // 实际应用中应使用加密
        userService.updateById(user);
        return R.ok("密码已重置为123456");
    }

    // 分页查询用户列表
    @GetMapping("/list")
    public R listUsers(@RequestParam Map params, UserEntity userQuery) {
        EntityWrapper<UserEntity> wrapper = new EntityWrapper<>();
        MPUtil.allLike(wrapper, userQuery);
        MPUtil.between(wrapper, params);
        PageUtils page = userService.queryPage(params, MPUtil.sort(wrapper, params));
        return R.ok().put("data", page);
    }
}

系统界面展示

管理员可通过后台界面完成用户管理、电脑类型维护、品牌信息编辑及评测内容审核等操作。以下为关键功能页面示意图:

  • 用户管理界面支持增删改查操作,便于维护平台用户数据。
  • 电脑类型管理允许管理员定义如"游戏本"、"轻薄本"等分类。
  • 电脑信息管理界面提供完整的设备录入表单,包含型号、配置、价格等字段。
  • 普通用户登录后可在首页浏览最新电脑信息,并通过"我的收藏"查看感兴趣的内容。
  • 评测中心页面展示专业测评报告,用户可发表评论并与他人互动。
用户管理界面 电脑类型管理界面 电脑信息管理界面 用户首页浏览界面 电脑评测详情界面 我的收藏界面

整体系统界面简洁直观,操作流畅,功能覆盖全面,有效提升了电脑评测信息的组织与传播效率。

标签: SSMVueMySQLJava

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。