文末获取源码 

开发语言:Java

开发工具:IDEA /​​Eclipse​​

数据库:MYSQL5.7

应用服务:Tomcat7/Tomcat8

使用​​框架​​ssm+vue

JDK版本:jdk1.8


学生成绩是高校人才培养计划的重要组成部分,是实现人才培养目标、培养学生科研能力与创新思维、检验学生综合素质与实践能力的重要手段与综合性实践教学环节。而学生所在学院多采用半手工管理学生成绩的方式,所以有必要开发学生成绩管理系统来对学生成绩档案进行数字化管理。既可减轻学院教职员工工作压力,比较系统地对教务、教学上的各项服务和信息进行管理,又可加快成绩查询速度、加强成绩管理,跟上国家各部门关于信息化的步伐,使各项管理更加规范化。 正是针对上述问题,本论文对学生成绩管理系统的开发过程进行了较为详细的论述,本程序采用B/S架构、ssm 框架和 java 开发的 Web 框架, eclipse开发工具。

学生成绩管理系统的主要使用者分为管理员、教师和学生,实现功能包括管理员权限:首页、个人中心、学生管理、教师管理、优秀教师管理、优秀班主任管理、学校简介管理、教学课件管理、在线答疑管理、公告信息管理、优秀学生管理、班级成绩管理、学生成绩管理、试题管理、试卷管理、系统管理、考试管理等功能。教师后台权限:首页、个人中心、教学课件管理、在线答疑管理、优秀学生管理、班级成绩管理、学生成绩管理、试题管理、试卷管理、考试管理等等。学生后台权限:首页、个人中心、在线答疑管理、班级成绩管理、学生成绩管理、我的收藏管理、考试管理等等。由于本网站的功能模块设计比较全面,所以使得整个学生成绩管理系统信息管理的过程得以实现。

本系统的使用可以实现本学生成绩管理系统信息管理信息化,可以方便管理员进行更加方便快捷的管理,可以提高工作人员的管理效率。

系统设计

系统概要设计

本学生成绩管理系统选择B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式。适合在互联网上进行操作,只要学生能连网,任何时间、任何地点都可以进行系统的操作使用。系统工作原理图如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_前端

 系统结构设计

整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计。

本学生成绩管理系统结构图如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_ssm_02


系统详细设计

用户前后功能模块  

学生成绩管理系统设计;主要实现首页、优秀教师、优秀班主任、学校简介、教学课件、公告信息、优秀学生、试卷列表、新闻资讯、我的、跳转到后台,功能。网站首页效果如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_后端_03

SpringMVC+vue实现前后端分离的学生成绩管理系统_java_04

优秀教师,在优秀教师页面可以填写标题、教师工号、荣誉等详细,如图1,图2所示:学校简介,在学校简介页面可以填写校园风采、校园简介等详细,如图3

SpringMVC+vue实现前后端分离的学生成绩管理系统_java_05

SpringMVC+vue实现前后端分离的学生成绩管理系统_vue_06

优秀学生,在优秀学生页面可以填写标题、年级、班级、学生学号、学生成绩、发布时间等详细,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_前端_07

试卷列表

SpringMVC+vue实现前后端分离的学生成绩管理系统_ssm_08

 管理员功能模块

管理员登录,管理员通过输入用户名、密码,角色进行系统登录,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_前端_09

学生管理,在学生管理可以查看学生学号、学生姓名、密码、年级、班级、性别、联系电话、邮箱、身份证等信息并进行添加、删除、修改操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_后端_10 

教师管理,在教师管理页面通过教师工号、密码、教师姓名、性别、职称、联系电话、教师邮箱并进行添加、删除、修改等操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_vue_11

优秀教师管理,在优秀教师管理页面通过标题、教师工号、教师姓名、封面、荣誉等并进行添加、删除、修改以及查看等操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_java_12 

优秀班主任管理,在优秀班主任管理页面通过标题、教师工号、教师姓名、职称、封面等并进行添加、删除、修改以及查看操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_后端_13 

 教学课件管理,在教学课件管理页面通过标题、文件、封面、教师工号、教师姓名、发布时间等并进行添加、删除、修改以及查看操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_后端_14

公告信息管理,在公告信息管理页面通过标题、封面、发布时间等并进行添加、删除、修改以及查看操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_前端_15 

优秀学生管理,在优秀学生管理页面通过标题、年级、班级、学生学号、学生成绩、发布时间、封面等并进行添加、删除、修改以及查看操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_ssm_16 

学生成绩管理,在学生成绩管理页面通过标题、学生学号、科目、成绩、班排名、发布时间等并进行添加、删除、修改以及查看操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_前端_17 

教师功能模块 

教师登录,教师通过输入用户名,密码、角色进行系统登录,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_java_18

个人信息,在个人信息页面通过教师工号、密码、教师姓名、性别、职称、联系电话、教师邮箱等并进行添加、删除、修改以及查看操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_ssm_19 

优秀学生管理在优秀学生管理页面通过标题、年级、班级、学生学号、学生成绩、发布时间、封面等并进行添加、删除、修改以及查看操作,如图 

SpringMVC+vue实现前后端分离的学生成绩管理系统_ssm_20

班级成绩管理,在班级成绩管理页面通过标题、年级、班级、科目、总成绩、平均分、教师工号、登记时间等并进行添加、删除、修改以及查看操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_vue_21

学生成绩,在学生成绩页面中可以查看标题、学生学号、科目、成绩、班排名、发布时间等详细操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_前端_22 

试卷管理,在试卷管理页面中可以查看试卷名称、考试时长、试卷状态等详细信息,并进行添加、删除、修改操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_后端_23 

学生功能模块 

 学生登录,学生通过输入用户名,密码、角色进行系统登录,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_vue_24

在线答疑管理,在线答疑管理页面通过教师工号、学生学号、学生姓名、留言时间、审核回复等并进行详情操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_vue_25 

班级成绩管理,在班级成绩管理页面中可以查看标题、年级、班级、科目、总成绩、平均分、教师工号、登记时间等详细操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_后端_26

学生成绩管理,在学生成绩管理页面中可以查看标题、学生学号、科目、成绩、班排名、发布时间等详细操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_ssm_27 

考试管理,在考试管理页面中可以查看试卷、考试时长/分钟等详细操作,如图

SpringMVC+vue实现前后端分离的学生成绩管理系统_ssm_28 

 部分核心代码: 

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);
}



}