SpringMVC+vue实现前后端分离的学生成绩管理系统
开发语言:Java 开发工具:IDEA / 数据库:MYSQL5.7 应用服务:Tomcat7/Tomcat8 使用ssm+vue JDK版本:jdk1.8
学生成绩是高校人才培养计划的重要组成部分,是实现人才培养目标、培养学生科研能力与创新思维、检验学生综合素质与实践能力的重要手段与综合性实践教学环节。而学生所在学院多采用半手工管理学生成绩的方式,所以有必要开发学生成绩管理系统来对学生成绩档案进行数字化管理。既可减轻学院教职员工工作压力,比较系统地对教务、教学上的各项服务和信息进行管理,又可加快成绩查询速度、加强成绩管理,跟上国家各部门关于信息化的步伐,使各项管理更加规范化。 正是针对上述问题,本论文对学生成绩管理系统的开发过程进行了较为详细的论述,本程序采用B/S架构、ssm 框架和 java 开发的 Web 框架, eclipse开发工具。
本系统的使用可以实现本学生成绩管理系统信息管理信息化,可以方便管理员进行更加方便快捷的管理,可以提高工作人员的管理效率。
系统设计
系统概要设计
本学生成绩管理系统选择B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式。适合在互联网上进行操作,只要学生能连网,任何时间、任何地点都可以进行系统的操作使用。系统工作原理图如图
系统结构设计
整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计。
本学生成绩管理系统结构图如图
系统详细设计
用户前后功能模块
学生成绩管理系统设计;主要实现首页、优秀教师、优秀班主任、学校简介、教学课件、公告信息、优秀学生、试卷列表、新闻资讯、我的、跳转到后台,功能。网站首页效果如图
优秀教师,在优秀教师页面可以填写标题、教师工号、荣誉等详细,如图1,图2所示:学校简介,在学校简介页面可以填写校园风采、校园简介等详细,如图3
优秀学生,在优秀学生页面可以填写标题、年级、班级、学生学号、学生成绩、发布时间等详细,如图
试卷列表
管理员功能模块
管理员登录,管理员通过输入用户名、密码,角色进行系统登录,如图
学生管理,在学生管理可以查看学生学号、学生姓名、密码、年级、班级、性别、联系电话、邮箱、身份证等信息并进行添加、删除、修改操作,如图
教师管理,在教师管理页面通过教师工号、密码、教师姓名、性别、职称、联系电话、教师邮箱并进行添加、删除、修改等操作,如图
优秀教师管理,在优秀教师管理页面通过标题、教师工号、教师姓名、封面、荣誉等并进行添加、删除、修改以及查看等操作,如图
优秀班主任管理,在优秀班主任管理页面通过标题、教师工号、教师姓名、职称、封面等并进行添加、删除、修改以及查看操作,如图
教学课件管理,在教学课件管理页面通过标题、文件、封面、教师工号、教师姓名、发布时间等并进行添加、删除、修改以及查看操作,如图
公告信息管理,在公告信息管理页面通过标题、封面、发布时间等并进行添加、删除、修改以及查看操作,如图
优秀学生管理,在优秀学生管理页面通过标题、年级、班级、学生学号、学生成绩、发布时间、封面等并进行添加、删除、修改以及查看操作,如图
学生成绩管理,在学生成绩管理页面通过标题、学生学号、科目、成绩、班排名、发布时间等并进行添加、删除、修改以及查看操作,如图
教师功能模块
教师登录,教师通过输入用户名,密码、角色进行系统登录,如图
个人信息,在个人信息页面通过教师工号、密码、教师姓名、性别、职称、联系电话、教师邮箱等并进行添加、删除、修改以及查看操作,如图
优秀学生管理在优秀学生管理页面通过标题、年级、班级、学生学号、学生成绩、发布时间、封面等并进行添加、删除、修改以及查看操作,如图
班级成绩管理,在班级成绩管理页面通过标题、年级、班级、科目、总成绩、平均分、教师工号、登记时间等并进行添加、删除、修改以及查看操作,如图
学生成绩,在学生成绩页面中可以查看标题、学生学号、科目、成绩、班排名、发布时间等详细操作,如图
试卷管理,在试卷管理页面中可以查看试卷名称、考试时长、试卷状态等详细信息,并进行添加、删除、修改操作,如图
学生功能模块
学生登录,学生通过输入用户名,密码、角色进行系统登录,如图
在线答疑管理,在线答疑管理页面通过教师工号、学生学号、学生姓名、留言时间、审核回复等并进行详情操作,如图
班级成绩管理,在班级成绩管理页面中可以查看标题、年级、班级、科目、总成绩、平均分、教师工号、登记时间等详细操作,如图
学生成绩管理,在学生成绩管理页面中可以查看标题、学生学号、科目、成绩、班排名、发布时间等详细操作,如图
考试管理,在考试管理页面中可以查看试卷、考试时长/分钟等详细操作,如图
部分核心代码:
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.XueshengchengjiEntity; import com.entity.view.XueshengchengjiView; import com.service.XueshengchengjiService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 学生成绩 * 后端接口 * @author * @email * @date 2020-12-17 13:02:56 */ @RestController @RequestMapping("/xueshengchengji") public class XueshengchengjiController { @Autowired private XueshengchengjiService xueshengchengjiService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,XueshengchengjiEntity xueshengchengji, HttpServletRequest request){ String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("xuesheng")) { xueshengchengji.setXueshengxuehao((String)request.getSession().getAttribute("username")); } EntityWrapper<XueshengchengjiEntity> ew = new EntityWrapper<XueshengchengjiEntity>(); PageUtils page = xueshengchengjiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xueshengchengji), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,XueshengchengjiEntity xueshengchengji, HttpServletRequest request){ EntityWrapper<XueshengchengjiEntity> ew = new EntityWrapper<XueshengchengjiEntity>(); PageUtils page = xueshengchengjiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xueshengchengji), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( XueshengchengjiEntity xueshengchengji){ EntityWrapper<XueshengchengjiEntity> ew = new EntityWrapper<XueshengchengjiEntity>(); ew.allEq(MPUtil.allEQMapPre( xueshengchengji, "xueshengchengji")); return R.ok().put("data", xueshengchengjiService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(XueshengchengjiEntity xueshengchengji){ EntityWrapper< XueshengchengjiEntity> ew = new EntityWrapper< XueshengchengjiEntity>(); ew.allEq(MPUtil.allEQMapPre( xueshengchengji, "xueshengchengji")); XueshengchengjiView xueshengchengjiView = xueshengchengjiService.selectView(ew); return R.ok("查询学生成绩成功").put("data", xueshengchengjiView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") String id){ XueshengchengjiEntity xueshengchengji = xueshengchengjiService.selectById(id); return R.ok().put("data", xueshengchengji); } /** * 前端详情 */ @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") String id){ XueshengchengjiEntity xueshengchengji = xueshengchengjiService.selectById(id); return R.ok().put("data", xueshengchengji); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody XueshengchengjiEntity xueshengchengji, HttpServletRequest request){ xueshengchengji.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(xueshengchengji); xueshengchengjiService.insert(xueshengchengji); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody XueshengchengjiEntity xueshengchengji, HttpServletRequest request){ xueshengchengji.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(xueshengchengji); xueshengchengjiService.insert(xueshengchengji); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody XueshengchengjiEntity xueshengchengji, HttpServletRequest request){ //ValidatorUtils.validateEntity(xueshengchengji); xueshengchengjiService.updateById(xueshengchengji);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ xueshengchengjiService.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) { 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) { 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<XueshengchengjiEntity> wrapper = new EntityWrapper<XueshengchengjiEntity>(); if(map.get("remindstart")!=null) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null) { 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")); } int count = xueshengchengjiService.selectCount(wrapper); return R.ok().put("count", count); } }