前言
本文拟采用java技术和ssm搭建系统框架,后台使用MySQL数据库进行信息管理,设计开发的学科竞赛全流程管理系统。通过调研和分析,系统拥有管理员、教师和学生三个角色,主要具备登录注册、个人信息修改、教师管理、学生管理、竞赛信息管理、竞赛报名管理、竞赛成绩管理、获奖展示管理、规则通知管理、竞赛经费管理、模拟训练管理、试题管理、管理员管理、系统管理、考试管理等功能模块。将纸质管理有效实现为在线管理,极大提高工作效率。
关键词:学科竞赛全流程;java;ssm框架;MySQL
一、项目介绍
学科竞赛全流程管理系统综合网络空间开发设计要求。目的是将学科竞赛全流程管理系统将传统管理方式转换为在网上管理,完成学科竞赛全流程的方便快捷、安全性高、交易规范做了保障,目标明确。学科竞赛全流程管理系统可以将功能划分为管理员功能、教师功能和学生功能。
(1)、管理员关键功能包含个人中心、教师管理、学生管理、竞赛信息管理、竞赛报名管理、竞赛成绩管理、获奖展示管理、规则通知管理、竞赛经费管理、模拟训练管理、试题管理、管理员管理、系统管理、考试管理等进行管理。管理员用例如下:
图3-1 管理员用例图
(2)、教师关键功能包含个个人中心、竞赛成绩管理、规则通知管理、模拟训练管理、试题管理、考试管理等进行管理。教师用例如下:
图3-2 教师用例图
(3)、学生关键功能包含首页、竞赛信息、规则通知、模拟训练、后台管理、个人中心等进行管理。学生用例如下:
图3-3学生用例图
二、开发环境
开发语言:Java
框架:ssm
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven
————————————————
三、功能介绍
四、核心代码
部分代码:
package com.example.controller;
import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.Caiwu;
import com.example.exception.CustomException;
import com.example.service.CaiwuService;
import com.example.utils.MapWrapperUtils;
import com.example.utils.jwt.JwtUtil;
import com.example.vo.CaiwuVo;
import org.springframework.beans.BeanUtils;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@RestController
@RequestMapping(value = "/caiwu")
public class CaiwuController {
@Resource
private CaiwuService caiwuService;
@PostMapping
public Result<Caiwu> add(@RequestBody CaiwuVo caiwu) {
caiwuService.add(caiwu);
return Result.success(caiwu);
}
@PostMapping("/deleteList")
public Result<Caiwu> deleteList(@RequestBody CaiwuVo caiwu) {
caiwuService.deleteList(caiwu.getList());
return Result.success();
}
@DeleteMapping("/{id}")
public Result delete(@PathVariable Long id) {
caiwuService.delete(id);
return Result.success();
}
@PutMapping
public Result update(@RequestBody CaiwuVo caiwu) {
caiwuService.update(caiwu);
return Result.success();
}
@GetMapping("/{id}")
public Result<Caiwu> detail(@PathVariable Integer id) {
Caiwu caiwu = caiwuService.findById(id);
return Result.success(caiwu);
}
@GetMapping
public Result<List<Caiwu>> all() {
return Result.success(caiwuService.list());
}
@PostMapping("/page")
public Result<CaiwuVo> page(@RequestBody CaiwuVo caiwuVo) {
return Result.success(caiwuService.findPage(caiwuVo));
}
@PostMapping("/login")
public Result login(@RequestBody Caiwu caiwu, HttpServletRequest request) {
if (StrUtil.isBlank(caiwu.getZhanghao()) || StrUtil.isBlank(caiwu.getMima())) {
throw new CustomException(ResultCode.PARAM_LOST_ERROR);
}
Caiwu login = caiwuService.login(caiwu);
// if(!login.getStatus()){
// return Result.error("1001","状态限制,无法登录系统");
// }
if(login != null) {
HashMap hashMap = new HashMap();
hashMap.put("user", login);
Map<String, Object> map = MapWrapperUtils.builder(MapWrapperUtils.KEY_USER_ID,caiwu.getId());
String token = JwtUtil.creatToken(map);
hashMap.put("token", token);
return Result.success(hashMap);
}else {
return Result.error();
}
}
@PutMapping("/updatePassword")
public Result updatePassword(@RequestBody Caiwu info, HttpServletRequest request) {
Caiwu caiwu = caiwuService.findById(info.getId());
String oldPassword = SecureUtil.md5(info.getMima());
if (!oldPassword.equals(caiwu.getMima())) {
return Result.error(ResultCode.PARAM_PASSWORD_ERROR.code, ResultCode.PARAM_PASSWORD_ERROR.msg);
}
info.setMima(SecureUtil.md5(info.getNewPassword()));
Caiwu caiwu1 = new Caiwu();
BeanUtils.copyProperties(info, caiwu1);
caiwuService.update(caiwu1);
return Result.success();
}
}
五、效果图
六、文章目录
目 录
目 录 III
第一章 概述 1
1.1 研究背景 1
1.2 研究目的及意义 1
1.3 国内外发展现状 1
1.4 研究内容 1
1.5 本文的结构 2
第二章 开发工具及技术介绍 3
2.1 Java编程语言 3
2.2 MySQL数据库 3
2.3 SSM框架 4
2.4 B/S架构 5
第三章 系统分析 1
3.1 功能需求分析 1
3.2 系统可行性分析 1
3.2.1技术可行性 1
3.2.2经济可行性 1
3.2.3社会可行性 2
3.3 系统用例分析 2
3.4 系统流程分析 3
3.4.1登录流程图 4
3.4.2添加新用户流程图 4
第四章 系统概要设计 6
4.1 系统设计原理 6
4.2 功能模块设计 6
4.3 数据库设计 6
4.3.1数据库设计原则 6
4.3.2数据库E-R图设计 7
4.3.3数据库表结构设计 9
第五章 系统功能实现 18
5.1系统功能实现 18
5.2后台模块实现 20
5.2.1管理员模块实现 21
5.2.2教师管理模块 26
5.2.3学生功能模块 27
第六章 系统测试 29
6.1系统测试的目的 29
6.2软件测试过程 29
6.3系统测试用例 29
结 论 31
致 谢 32
参考文献 33