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

高校体育馆预约管理系统的设计与实现

访客 技术 2026年7月5日 1

系统整体结构

本系统采用前后端分离的架构模式,结合MySQL数据库进行数据持久化存储。该设计有利于后期的功能拓展和代码维护。系统整体结构如下图所示:

系统架构图

界面展示

以下是系统的部分运行界面截图:

关键代码示例


/**
 * 用户操作控制器
 */
@RestController
@RequestMapping("/api/user")
public class UserAuthController {

    @Autowired
    private UserService userService;

    @Autowired
    private JwtTokenProvider tokenProvider;

    /**
     * 用户登录接口
     */
    @PostMapping("/login")
    public ResponseEntity authenticateUser(@RequestBody LoginRequest loginRequest) {
        String uname = loginRequest.getUsername();
        String pwd = loginRequest.getPassword();
        String userRole = loginRequest.getUserType();

        UserInfo userInfo = userService.findByUsername(uname);

        if (userInfo == null || !userInfo.getRole().equals(userRole)) {
            return ResponseEntity.badRequest().body("权限验证失败");
        }

        if (!pwd.equals(userInfo.getPassword())) {
            return ResponseEntity.badRequest().body("用户名或密码错误");
        }

        String jwtToken = tokenProvider.createToken(userInfo.getUserId(), uname, userInfo.getRole());
        return ResponseEntity.ok(new AuthResponse(jwtToken));
    }

    /**
     * 用户注册接口
     */
    @PostMapping("/register")
    public ResponseEntity registerUser(@RequestBody UserInfo newUser) {
        if (userService.existsByUsername(newUser.getUsername())) {
            return ResponseEntity.badRequest().body("该用户名已被注册");
        }
        userService.createUser(newUser);
        return ResponseEntity.ok("注册成功");
    }

    /**
     * 重置密码
     */
    @PutMapping("/reset-password")
    public ResponseEntity resetPassword(@RequestParam String username) {
        UserInfo user = userService.findByUsername(username);
        if (user == null) {
            return ResponseEntity.badRequest().body("用户不存在");
        }
        user.setPassword("123456");
        userService.updateUserInfo(user);
        return ResponseEntity.ok("密码已重置为默认值");
    }

    /**
     * 获取当前用户信息
     */
    @GetMapping("/profile")
    public ResponseEntity getCurrentUserProfile(HttpServletRequest request) {
        String userId = (String) request.getAttribute("userId");
        UserInfo user = userService.findById(userId);
        return ResponseEntity.ok(user);
    }
}

数据库初始化脚本


-- 删除旧表(如果存在)
DROP TABLE IF EXISTS user_accounts;

-- 创建用户账户表
CREATE TABLE user_accounts (
  account_id BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '唯一标识',
  account_name VARCHAR(100) NOT NULL COMMENT '登录名',
  account_password VARCHAR(100) NOT NULL COMMENT '登录密码',
  user_role VARCHAR(100) DEFAULT '普通用户' COMMENT '用户角色',
  created_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  PRIMARY KEY (account_id)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='用户信息表';

-- 插入初始管理员数据
INSERT INTO user_accounts(account_id, account_name, account_password, user_role, created_time) 
VALUES (1, 'admin', 'admin', '管理员', '2022-05-01 00:00:00');

技术选型说明

后端技术

选用Java作为主要开发语言,具备良好的跨平台特性和强大的生态系统。Spring Boot框架简化了配置流程,提高了开发效率。整个系统划分为表现层、业务逻辑层和数据访问层,层次清晰。

数据库技术

采用MySQL关系型数据库进行数据管理,其成熟的事务处理能力和高效的读写性能适合此类管理系统的需求。通过合理的索引优化和查询语句调优,保障系统响应速度。

相关文章

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...

发表评论

访客

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