项目编号:BS-GX-063
一,环境介绍
语言环境:Java: jdk1.8
数据库:Mysql: mysql5.7
应用服务器:Tomcat: tomcat8.5.31
开发工具:IDEA或eclipse
开发技术:SSM+VUE 前后端分离开发模式
二,项目简介
21世纪的今天,随着社会的不断发展与进步,人们对于信息科学化的认识,已由低层次向高层次发展,由原来的感性认识向理性认识提高,管理工作的重要性已逐渐被人们所认识,科学化的管理,使信息存储达到准确、快速、完善,并能提高工作管理效率,促进其发展。
论文主要是对毕业设计管理系统,进行了介绍,包括研究的现状,还有涉及的开发背景,然后还对系统的设计目标进行了论述,还有系统的需求,以及整个的设计方案,对系统的设计以及实现,也都论述的比较细致,最后对毕业设计管理系统 进行了一些具体测试。
本文以Java为开发技术,实现了一个毕业设计管理系统 。 毕业设计管理系统的主要实现功能包括:管理员:首页、个人中心、个人信息、学生管理、教师管理、文件模板管理 、论坛管理 、系统管理、在线选题管理、开题报告管理、中期报告管理、毕业论文管理等等。,教师管理:个人中心、个人信息、文件模板管理 、在线选题管理、老师答疑管理、开题报告管理、中期报告管理、毕业论文管理、学生提题管理、论文进度管理等等。学生管理:个人中心、个人信息、学生提问管理、 、老师答疑管理、开题报告管理、中期报告管理、毕业论文管理、学生提题管理、论文进度管理、我的收藏管理等等功能。通过这些功能模块的设计,基本上实现了整个毕业设计管理系统的过程。
具体在系统设计上,采用了B/S的结构,同时,也使用Java技术在动态页面上进行了设计,后台上采用Mysql数据库,是一个非常优秀的 毕业设计管理系统 。
以往的毕业设计管理系统相关信息管理,都是工作人员手工统计。这种方式不但时效性低,而且需要查找和变更的时候很不方便。随着科学的进步,技术的成熟,计算机信息化也日新月异的发展,社会也已经深刻的认识,计算机功能非常的强大,计算机已经进入了人类社会发展的各个领域,并且发挥着十分重要的作用。本系统利用网络沟通、计算机信息存储管理,有着与传统的方式所无法替代的优点。比如计算检索速度特别快、可靠性特别高、存储容量特别大、保密性特别好、可保存时间特别长、成本特别低等。在工作效率上,能够得到极大地提高,延伸至服务水平也会有好的收获,有了网络, 毕业设计管理系统的各方面的管理更加科学和系统,更加规范和简便。
系统中的核心角色是系统管理员,管理员登录后,通过管理员菜单来管理后台系统。主要功能有;首页、个人中心、个人信息、学生管理、教师管理、文件模板管理 、论坛管理 、系统管理、在线选题管理、开题报告管理、中期报告管理、毕业论文管理、学生提题管理、论文进度管理等功能。管理员用例如下图1所示。
教师:个人中心、个人信息、文件模板管理 、在线选题管理、老师答疑管理、开题报告管理、中期报告管理、毕业论文管理、学生提题管理、论文进度管理等功能。教师用例如图2所示。
学生:个人中心、个人信息、学生提问管理、 老师答疑管理、开题报告管理、
中期报告管理、毕业论文管理、学生提题管理、论文进度管理、我的收藏等功能。学生用例如图3所示。
系统整体功能架构图如下图4所示。
三,系统展示
3.1 前台功能模块
网站首页
网页首页电影订票系统模块如下:首页、在线选题、论坛、个人中心后台管理等功能图5-1
网页前台在线选题效果图如图5-2所示
学生注册
学生登陆
3.1 后台管理模块
管理员登陆
学生信息管理:管理员对学生信息进行学可以进行编辑生学号、学生姓名 、密码 、性别、 年级、 班级 、身份证、 联系电话添加、删除、修改以及查看、修改密码等操作。
教师管理:管理员对教师获取教师工号 教师姓名 密码 职称 联系电话 身份证 进行添加、删除、修改以及查看等操作。
系统管理:管理员通过系统管理页面查看轮播图、新闻资讯等进行上传图片进行添加、删除、修改以及查看并对整个系统进行维护等操作
在线选题管理:管理员对在线选题获取课题题目 图片 教师工号 发布时间 审核回复 审核等信息进行添加、查看、修改以及删除等操作。
中期报告管理:管理员对中期报告管理信息进行修改、审核、删除以及查看等操作
毕业论文管理:管理员对毕业论文管理信息进行修改、审核、删除以及查看等操作
学生提题管理:管理员对学生提题信息进行修改、审核、删除以及查看等操作。
文件模板管理:教师对系统文件模板管理进行添加、查看、修改以及删除等操作查看等操作。
四,核心代码展示
package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.XueshengtitiEntity; import com.entity.view.XueshengtitiView; import com.service.XueshengtitiService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 学生提题 * 后端接口 * @author * @email * @date 2023-04-02 10:24:02 */ @RestController @RequestMapping("/xueshengtiti") public class XueshengtitiController { @Autowired private XueshengtitiService xueshengtitiService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,XueshengtitiEntity xueshengtiti, HttpServletRequest request){ String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("xuesheng")) { xueshengtiti.setXueshengxuehao((String)request.getSession().getAttribute("username")); } if(tableName.equals("jiaoshi")) { xueshengtiti.setJiaoshigonghao((String)request.getSession().getAttribute("username")); } EntityWrapper<XueshengtitiEntity> ew = new EntityWrapper<XueshengtitiEntity>(); PageUtils page = xueshengtitiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xueshengtiti), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,XueshengtitiEntity xueshengtiti, HttpServletRequest request){ EntityWrapper<XueshengtitiEntity> ew = new EntityWrapper<XueshengtitiEntity>(); PageUtils page = xueshengtitiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xueshengtiti), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( XueshengtitiEntity xueshengtiti){ EntityWrapper<XueshengtitiEntity> ew = new EntityWrapper<XueshengtitiEntity>(); ew.allEq(MPUtil.allEQMapPre( xueshengtiti, "xueshengtiti")); return R.ok().put("data", xueshengtitiService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(XueshengtitiEntity xueshengtiti){ EntityWrapper< XueshengtitiEntity> ew = new EntityWrapper< XueshengtitiEntity>(); ew.allEq(MPUtil.allEQMapPre( xueshengtiti, "xueshengtiti")); XueshengtitiView xueshengtitiView = xueshengtitiService.selectView(ew); return R.ok("查询学生提题成功").put("data", xueshengtitiView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") String id){ XueshengtitiEntity xueshengtiti = xueshengtitiService.selectById(id); return R.ok().put("data", xueshengtiti); } /** * 前端详情 */ @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") String id){ XueshengtitiEntity xueshengtiti = xueshengtitiService.selectById(id); return R.ok().put("data", xueshengtiti); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody XueshengtitiEntity xueshengtiti, HttpServletRequest request){ xueshengtiti.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(xueshengtiti); xueshengtitiService.insert(xueshengtiti); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody XueshengtitiEntity xueshengtiti, HttpServletRequest request){ xueshengtiti.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(xueshengtiti); xueshengtitiService.insert(xueshengtiti); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody XueshengtitiEntity xueshengtiti, HttpServletRequest request){ //ValidatorUtils.validateEntity(xueshengtiti); xueshengtitiService.updateById(xueshengtiti);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ xueshengtitiService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ @RequestMapping("/remind/{columnName}/{type}") public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) { map.put("column", columnName); map.put("type", type); if(type.equals("2")) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar c = Calendar.getInstance(); Date remindStartDate = null; Date remindEndDate = null; if(map.get("remindstart")!=null && !map.get("remindstart").toString().equals("")) { Integer remindStart = Integer.parseInt(map.get("remindstart").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate = c.getTime(); map.put("remindstart", sdf.format(remindStartDate)); } if(map.get("remindend")!=null && !map.get("remindend").toString().equals("")) { Integer remindEnd = Integer.parseInt(map.get("remindend").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate = c.getTime(); map.put("remindend", sdf.format(remindEndDate)); } } Wrapper<XueshengtitiEntity> wrapper = new EntityWrapper<XueshengtitiEntity>(); if(map.get("remindstart")!=null && !map.get("remindstart").toString().equals("")) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null && !map.get("remindend").toString().equals("")) { wrapper.le(columnName, map.get("remindend")); } String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("xuesheng")) { wrapper.eq("xueshengxuehao", (String)request.getSession().getAttribute("username")); } if(tableName.equals("jiaoshi")) { wrapper.eq("jiaoshigonghao", (String)request.getSession().getAttribute("username")); } int count = xueshengtitiService.selectCount(wrapper); return R.ok().put("count", count); } }
package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.ZhongqibaogaoEntity; import com.entity.view.ZhongqibaogaoView; import com.service.ZhongqibaogaoService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 中期报告 * 后端接口 * @author * @email * @date 2023-04-02 10:24:01 */ @RestController @RequestMapping("/zhongqibaogao") public class ZhongqibaogaoController { @Autowired private ZhongqibaogaoService zhongqibaogaoService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,ZhongqibaogaoEntity zhongqibaogao, HttpServletRequest request){ String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("xuesheng")) { zhongqibaogao.setXueshengxuehao((String)request.getSession().getAttribute("username")); } if(tableName.equals("jiaoshi")) { zhongqibaogao.setJiaoshigonghao((String)request.getSession().getAttribute("username")); } EntityWrapper<ZhongqibaogaoEntity> ew = new EntityWrapper<ZhongqibaogaoEntity>(); PageUtils page = zhongqibaogaoService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zhongqibaogao), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,ZhongqibaogaoEntity zhongqibaogao, HttpServletRequest request){ EntityWrapper<ZhongqibaogaoEntity> ew = new EntityWrapper<ZhongqibaogaoEntity>(); PageUtils page = zhongqibaogaoService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zhongqibaogao), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( ZhongqibaogaoEntity zhongqibaogao){ EntityWrapper<ZhongqibaogaoEntity> ew = new EntityWrapper<ZhongqibaogaoEntity>(); ew.allEq(MPUtil.allEQMapPre( zhongqibaogao, "zhongqibaogao")); return R.ok().put("data", zhongqibaogaoService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(ZhongqibaogaoEntity zhongqibaogao){ EntityWrapper< ZhongqibaogaoEntity> ew = new EntityWrapper< ZhongqibaogaoEntity>(); ew.allEq(MPUtil.allEQMapPre( zhongqibaogao, "zhongqibaogao")); ZhongqibaogaoView zhongqibaogaoView = zhongqibaogaoService.selectView(ew); return R.ok("查询中期报告成功").put("data", zhongqibaogaoView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") String id){ ZhongqibaogaoEntity zhongqibaogao = zhongqibaogaoService.selectById(id); return R.ok().put("data", zhongqibaogao); } /** * 前端详情 */ @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") String id){ ZhongqibaogaoEntity zhongqibaogao = zhongqibaogaoService.selectById(id); return R.ok().put("data", zhongqibaogao); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody ZhongqibaogaoEntity zhongqibaogao, HttpServletRequest request){ zhongqibaogao.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(zhongqibaogao); zhongqibaogaoService.insert(zhongqibaogao); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody ZhongqibaogaoEntity zhongqibaogao, HttpServletRequest request){ zhongqibaogao.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(zhongqibaogao); zhongqibaogaoService.insert(zhongqibaogao); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody ZhongqibaogaoEntity zhongqibaogao, HttpServletRequest request){ //ValidatorUtils.validateEntity(zhongqibaogao); zhongqibaogaoService.updateById(zhongqibaogao);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ zhongqibaogaoService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ @RequestMapping("/remind/{columnName}/{type}") public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) { map.put("column", columnName); map.put("type", type); if(type.equals("2")) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar c = Calendar.getInstance(); Date remindStartDate = null; Date remindEndDate = null; if(map.get("remindstart")!=null && !map.get("remindstart").toString().equals("")) { Integer remindStart = Integer.parseInt(map.get("remindstart").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate = c.getTime(); map.put("remindstart", sdf.format(remindStartDate)); } if(map.get("remindend")!=null && !map.get("remindend").toString().equals("")) { Integer remindEnd = Integer.parseInt(map.get("remindend").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate = c.getTime(); map.put("remindend", sdf.format(remindEndDate)); } } Wrapper<ZhongqibaogaoEntity> wrapper = new EntityWrapper<ZhongqibaogaoEntity>(); if(map.get("remindstart")!=null && !map.get("remindstart").toString().equals("")) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null && !map.get("remindend").toString().equals("")) { wrapper.le(columnName, map.get("remindend")); } String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("xuesheng")) { wrapper.eq("xueshengxuehao", (String)request.getSession().getAttribute("username")); } if(tableName.equals("jiaoshi")) { wrapper.eq("jiaoshigonghao", (String)request.getSession().getAttribute("username")); } int count = zhongqibaogaoService.selectCount(wrapper); return R.ok().put("count", count); } }
五,项目总结
数据库的表信息属于设计的一部分,下面介绍数据库中的各个表的详细信息。
表 guanliyuanxinxi表
列名 |
数据类型 |
长度 |
约束 |
id |
int |
11 |
PRIMARY KEY |
username |
varchar |
50 |
DEFAULT NULL |
pwd |
varchar |
50 |
DEFAULT NULL |
cx |
varchar |
50 |
DEFAULT NULL |
表3 xuesheng表
列名 |
数据类型 |
长度 |
约束 |
id |
int |
10 |
PRIMARY KEY |
xueshengxuehao |
int |
50 |
DEFAULT NULL |
xueshengxingming |
varchar |
50 |
DEFAULT NULL |
xingbie |
varchar |
50 |
DEFAULT NULL |
nianji |
varchar |
50 |
DEFAULT NULL |
banji |
varchar |
50 |
DEFAULT NULL |
shenfenzheng |
varchar |
50 |
DEFAULT NULL |
lianxidianhua |
varchar |
50 |
DEFAULT NULL |
表5 jiaoshi数据表
列名 |
数据类型 |
长度 |
约束 |
id |
int |
11 |
PRIMARY KEY |
jiaoshigonghao |
varchar |
50 |
DEFAULT NULL |
jiaoshixingming |
varchar |
50 |
DEFAULT NULL |
mima |
varchar |
50 |
DEFAULT NULL |
zhicheng |
varchar |
50 |
DEFAULT NULL |
lianxidianhua |
int |
10 |
DEFAULT NULL |
shenfenzheng |
int |
500 |
DEFAULT NULL |
表6`zaixianxuanti数据表
列名 |
数据类型 |
长度 |
约束 |
id |
int |
11 |
PRIMARY KEY |
ketitimu |
varchar |
10 |
DEFAULT NULL |
tupian |
varchar |
500 |
DEFAULT NULL |
jianjie |
varchar |
20 |
DEFAULT NULL |
jiaoshigonghao |
varchar |
4 |
DEFAULT NULL |
fabushijian |
varchar |
20 |
DEFAULT NULL |
sfsh |
varchar |
20 |
DEFAULT NULL |
shhf |
varchar |
20 |
DEFAULT NULL |
表6`xueshengtiwen数据表
列名 |
数据类型 |
长度 |
约束 |
id |
int |
11 |
PRIMARY KEY |
woyaotiwen |
varchar |
10 |
DEFAULT NULL |
xueshengxuehao |
varchar |
500 |
DEFAULT NULL |
xueshengxingming |
varchar |
20 |
DEFAULT NULL |
jiaoshigonghao |
varchar |
4 |
DEFAULT NULL |
jiaoshixingming |
varchar |
20 |
DEFAULT NULL |
tiwenshijian |
varchar |
20 |
DEFAULT NULL |
表6`laoshidayi数据表
列名 |
数据类型 |
长度 |
约束 |
id |
int |
11 |
PRIMARY KEY |
laoshidayi |
varchar |
10 |
DEFAULT NULL |
xueshengxuehao |
varchar |
500 |
DEFAULT NULL |
xueshengxingming |
varchar |
20 |
DEFAULT NULL |
jiaoshigonghao |
varchar |
4 |
DEFAULT NULL |
jiaoshixingming |
varchar |
20 |
DEFAULT NULL |
dayishijian |
varchar |
20 |
DEFAULT NULL |