• SpringBoot+Vue实现前后端分离的中学成绩管理系统


    文末获取源码

    开发语言:Java

    使用框架:spring boot

    前端技术:JavaScript、Vue.js 、css3

    开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code

    数据库:MySQL 5.7/8.0

    数据库管理工具:phpstudy/Navicat

    JDK版本:Java jdk8

    Maven:apache-maven 3.8.1-bin

    目录

    一、前言介绍 

    二、功能需求分析

    2.1学生模块

    2.2教师模块

    2.3管理员模块

    三、管理员功能模块 

    3.1系统登录界面 

    3.2系统首页模块

    3.3学生管理模块 

    3.4学生成绩管理模块

    5.5科目成绩统计管理模块 

    四、学生功能模块 

     4.1学生成绩模块

    4.2总分排名模块

    五、教师功能模块 

    5.1学生成绩添加页面

    六、部分核心代码

    6.1成绩添加关键代码

    6.2系统学生管理关键代码 

    6.3密码修改关键代码

    6.4总分排名信息添加关键代码

    6.5教师管理关键代码

    6.6班级成绩管理关键代码


    一、前言介绍 

    本设计主要实现集人性化、高效率、便捷等优点于一身的中学成绩管理系统,完成班级成绩管理、总分排名管理、课程管理、科目成绩统计管理、科目成绩分析管理、等功能模块。系统通过浏览器与服务器进行通信,实现数据的交互与变更。只需通过一台电脑,动动手指就可以操作系统,实现数据通信管理。整个系统的设计过程都充分考虑了数据的安全、稳定及可靠等问题,而且操作过程简单。本系统通过科学的管理方式、便捷的服务提高了工作效率,减少了数据存储上的错误和遗漏。中学成绩管理系统使用Java语言,采取Mysql作为后台数据的主要存储单元,采用Springboot架、Vue技术、Ajax技术进行业务系统的编码及其开发,实现了本系统的全部功能。

    二、功能需求分析

    中学成绩管理系统在对需求做解析后,整个系统主要分为两个部分:管理员和普通用户(教师、学生),每个模块下的分支功能不一样。对功能做出如下说明:

    2.1学生模块

    (1)账号登录认证。

    (2)管理个人资料信息,修改可修改的信息项。

    (3)成绩排名查询,同时查看历史已有成绩排名的记录。

    2.2教师模块

    (1)提交学生成绩,同时查看历史已提交的学生成绩记录。

    (2)成绩排名查询,同时查看历史已有成绩排名的记录。

    (3)科目成绩统计,统计班级学生成绩信息。

    (4)科目成绩分析,分析班级学生成绩排名情况。

    2.3管理员模块

    (1)维护学生,审核学生的账号,可以冻结学生的登录权限,或者删除学生账号。

    (2)发布成绩,并可以销毁某个成绩,更新成绩数据,模糊搜索成绩数据等。

    (3)发布教师,并可以销毁某个教师,更新教师数据,模糊搜索教师数据等。

    (4)管理成绩排名数据。

    (5)查看教师提交的学生成绩数据,管理员有权利维护它。 

    三、管理员功能模块 

    3.1系统登录界面 

    3.2系统首页模块

    3.3学生管理模块 

    3.4学生成绩管理模块

    5.5科目成绩统计管理模块 

    四、学生功能模块 

     4.1学生成绩模块

    4.2总分排名模块

    五、教师功能模块 

    5.1学生成绩添加页面

    六、部分核心代码

    6.1成绩添加关键代码

    1. @PostMapping("/add")
    2. @Transactional
    3. public Map<String, Object> add(HttpServletRequest request) throws IOException {
    4. service.insert(service.readBody(request.getReader()));
    5. return success(1);
    6. }
    7. @Transactional
    8. public Map<String, Object> addMap(Map<String,Object> map){
    9. service.insert(map);
    10. return success(1);
    11. }
    12. public Map<String,Object> readBody(BufferedReader reader){
    13. BufferedReader br = null;
    14. StringBuilder sb = new StringBuilder("");
    15. try{
    16. br = reader;
    17. String str;
    18. while ((str = br.readLine()) != null){
    19. sb.append(str);
    20. }
    21. br.close();
    22. String json = sb.toString();
    23. return JSONObject.parseObject(json, Map.class);
    24. }catch (IOException e){
    25. e.printStackTrace();
    26. }finally{
    27. if (null != br){
    28. try{
    29. br.close();
    30. }catch (IOException e){
    31. e.printStackTrace();
    32. }
    33. }
    34. }
    35. return null;
    36. }
    37. public void insert(Map<String,Object> body){
    38. StringBuffer sql = new StringBuffer("INSERT INTO ");
    39. sql.append("`").append(table).append("`").append(" (");
    40. for (Map.Entry<String,Object> entry:body.entrySet()){
    41. sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
    42. }
    43. sql.deleteCharAt(sql.length()-1);
    44. sql.append(") VALUES (");
    45. for (Map.Entry<String,Object> entry:body.entrySet()){
    46. Object value = entry.getValue();
    47. if (value instanceof String){
    48. sql.append("'").append(entry.getValue()).append("'").append(",");
    49. }else {
    50. sql.append(entry.getValue()).append(",");
    51. }
    52. }
    53. sql.deleteCharAt(sql.length() - 1);
    54. sql.append(")");
    55. log.info("[{}] - 插入操作:{}",table,sql);
    56. Query query = runCountSql(sql.toString());
    57. query.executeUpdate();
    58. }

    6.2系统学生管理关键代码 

    1. @RequestMapping(value = {"/avg_group", "/avg"})
    2. public Map<String, Object> avg(HttpServletRequest request) {
    3. Query count = service.avg(service.readQuery(request), service.readConfig(request));
    4. return success(count.getResultList());
    5. }

    6.3密码修改关键代码

    1. /**
    2. * 修改密码
    3. * @param data
    4. * @param request
    5. * @return
    6. */
    7. @PostMapping("change_password")
    8. public Map<String, Object> change_password(@RequestBody Map<String, String> data, HttpServletRequest request){
    9. // 根据Token获取UserId
    10. String token = request.getHeader("x-auth-token");
    11. Integer userId = tokenGetUserId(token);
    12. // 根据UserId和旧密码获取用户
    13. Map<String, String> query = new HashMap<>();
    14. String o_password = data.get("o_password");
    15. query.put("user_id" ,String.valueOf(userId));
    16. query.put("password" ,service.encryption(o_password));
    17. Query ret = service.count(query, service.readConfig(request));
    18. List list = ret.getResultList();
    19. Object s = list.get(0);
    20. int count = Integer.parseInt(list.get(0).toString());
    21. if(count > 0){
    22. // 修改密码
    23. Map<String,Object> form = new HashMap<>();
    24. form.put("password",service.encryption(data.get("password")));
    25. service.update(query,service.readConfig(request),form);
    26. return success(1);
    27. }
    28. return error(10000,"密码修改失败!");
    29. }

    6.4总分排名信息添加关键代码

    1. @RequestMapping("/get_list")
    2. public Map<String, Object> getList(HttpServletRequest request) {
    3. Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
    4. return success(map);
    5. }

    6.5教师管理关键代码

    1. @RestController
    2. @RequestMapping("auth")
    3. public class AuthController extends BaseController, AuthService> {
    4. /**
    5. * 服务对象
    6. */
    7. @Autowired
    8. public AuthController(AuthService service) {
    9. setService(service);
    10. }
    11. }

    6.6班级成绩管理关键代码

    1. @PostMapping("/set")
    2. @Transactional
    3. public Map<String, Object> set(HttpServletRequest request) throws IOException {
    4. service.update(service.readQuery(request), service.readConfig(request), service.readBody(request.getReader()));
    5. return success(1);
    6. }
    7. public Map<String,String> readConfig(HttpServletRequest request){
    8. Map<String,String> map = new HashMap<>();
    9. map.put(FindConfig.PAGE,request.getParameter(FindConfig.PAGE));
    10. map.put(FindConfig.SIZE,request.getParameter(FindConfig.SIZE));
    11. map.put(FindConfig.LIKE,request.getParameter(FindConfig.LIKE));
    12. map.put(FindConfig.ORDER_BY,request.getParameter(FindConfig.ORDER_BY));
    13. map.put(FindConfig.FIELD,request.getParameter(FindConfig.FIELD));
    14. map.put(FindConfig.GROUP_BY,request.getParameter(FindConfig.GROUP_BY));
    15. map.put(FindConfig.MAX_,request.getParameter(FindConfig.MAX_));
    16. map.put(FindConfig.MIN_,request.getParameter(FindConfig.MIN_));
    17. return map;
    18. }
    19. public Map<String,String> readQuery(HttpServletRequest request){
    20. String queryString = request.getQueryString();
    21. if (queryString != null && !"".equals(queryString)) {
    22. String[] querys = queryString.split("&");
    23. Map<String, String> map = new HashMap<>();
    24. for (String query : querys) {
    25. String[] q = query.split("=");
    26. map.put(q[0], q[1]);
    27. }
    28. map.remove(FindConfig.PAGE);
    29. map.remove(FindConfig.SIZE);
    30. map.remove(FindConfig.LIKE);
    31. map.remove(FindConfig.ORDER_BY);
    32. map.remove(FindConfig.FIELD);
    33. map.remove(FindConfig.GROUP_BY);
    34. map.remove(FindConfig.MAX_);
    35. map.remove(FindConfig.MIN_);
    36. return map;
    37. }else {
    38. return new HashMap<>();
    39. }
    40. }
    41. @Transactional
    42. public void update(Map<String,String> query,Map<String,String> config,Map<String,Object> body){
    43. StringBuffer sql = new StringBuffer("UPDATE ").append("`").append(table).append("`").append(" SET ");
    44. for (Map.Entry<String,Object> entry:body.entrySet()){
    45. Object value = entry.getValue();
    46. if (value instanceof String){
    47. sql.append("`"+humpToLine(entry.getKey())+"`").append("=").append("'").append(value).append("'").append(",");
    48. }else {
    49. sql.append("`"+humpToLine(entry.getKey())+"`").append("=").append(value).append(",");
    50. }
    51. }
    52. sql.deleteCharAt(sql.length()-1);
    53. sql.append(toWhereSql(query,"0".equals(config.get(FindConfig.LIKE))));
    54. log.info("[{}] - 更新操作:{}",table,sql);
    55. Query query1 = runCountSql(sql.toString());
    56. query1.executeUpdate();
    57. }
    58. public String toWhereSql(Map<String,String> query, Boolean like) {
    59. if (query.size() > 0) {
    60. try {
    61. StringBuilder sql = new StringBuilder(" WHERE ");
    62. for (Map.Entry<String, String> entry : query.entrySet()) {
    63. if (entry.getKey().contains(FindConfig.MIN_)) {
    64. String min = humpToLine(entry.getKey()).replace("_min", "");
    65. sql.append("`"+min+"`").append(" >= '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("' and ");
    66. continue;
    67. }
    68. if (entry.getKey().contains(FindConfig.MAX_)) {
    69. String max = humpToLine(entry.getKey()).replace("_max", "");
    70. sql.append("`"+max+"`").append(" <= '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("' and ");
    71. continue;
    72. }
    73. if (like == true) {
    74. sql.append("`"+humpToLine(entry.getKey())+"`").append(" LIKE '%").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("%'").append(" and ");
    75. } else {
    76. sql.append("`"+humpToLine(entry.getKey())+"`").append(" = '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("'").append(" and ");
    77. }
    78. }
    79. sql.delete(sql.length() - 4, sql.length());
    80. sql.append(" ");
    81. return sql.toString();
    82. } catch (UnsupportedEncodingException e) {
    83. log.info("拼接sql 失败:{}", e.getMessage());
    84. }
    85. }
    86. return "";
    87. }
  • 相关阅读:
    零数科技携手云南能投智慧打造全国最大区块链实体项目
    突破众多技术干货的迷茫
    【经典算法学习-排序篇】顺序查找 - 作业讲解
    startActivityForResult废弃了,用Activity Result API吧
    初学Vue(全家桶)-第18天(vue3):compositionAPI-组合API
    关于Vue的一些高频面试题总结
    化妆品展示网页设计作业 静态HTML化妆品网站 DW美妆网站模板下载 大学生简单网页作品代码 个人网页制作 学生个人网页设计作业
    根号分治
    【三维目标检测】VoteNet(一)
    机械转计算机,成功上岸鹅厂。白菜价年薪40w
  • 原文地址:https://blog.csdn.net/m0_49113107/article/details/127741139