文末获取源码

开发语言: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

一、前言介绍

教务评教系统的本设计主要实现集人性化、高效率、便捷等优点于一身的教务评教系统,完成首页、用户管理(管理员、教师用户、学生用户)更多管理(课程信息、选课信息、评价信息)等功能模块。系统通过浏览器与服务器进行通信,实现数据的交互与变更。只需通过一台电脑,动动手指就可以操作系统,实现数据通信管理。整个系统的设计过程都充分考虑了数据的安全、稳定及可靠等问题,而且操作过程简单。本系统通过科学的管理方式、便捷的服务提高了工作效率,减少了数据存储上的错误和遗漏。

教务评教系统使用Java语言,使用SpringBoot 技术开发,数据方面主要采用的是微软的MySQL关系型数据库来作为数据存储媒介完成系统的开发。

二、系统功能

教务评教系统在对需求做解析后,整个系统主要分为管理员和教师、学生,每个模块下的分支功能不一样。

(1)学生:个人资料管理、课程信息、选课信息、评价信息。

(2)教师:个人资料管理、课程信息、选课信息、评价信息。

(3)管理员:首页、系统用户设置、用户管理(管理员、教师用户、学生用户)更多管理(课程信息、选课信息、评价信息)管理等模块。

三、系统实现

3.1系统登录页面

3.2系统用户管理模块

管理员后台功能为:首页、用户管理(管理员、教师用户、学生用户)更多管理(课程信息、选课信息、评价信息)等功能,如下图

3.3学生管理模块

在学生管理界面图可对添加学生信息内容:学号、密码、学生姓名、性别、身份证、电话、院系、班级、照片等信息,并可在学生管理查询页面进行编辑删除详情等操作,如图

3.4教师管理模块

在教师管理页面中对教师进行添加信息内容:教师工号、密码、教师姓名、性别、身份证、电话、职称、主教课程、照片等内容,还可在教师查询页面对已有的教师信息进行编辑删除详情等操作,如图 

四、教师功能模块

4.1课程管理模块

在课程管理页面图中可以添加课程内容:教师工号、教师姓名、课程编号、课程名称、学时、学分、上课时间、上课地点等内容,还可在课程管理查询页面对已有的课程进行评价汇总,编辑删除详情等操作 如图

4.2评价信息管理模块

五、学生功能模块

5.1学生选课管理

在学生选课管理可查询选课列表信息:序号、课程编号、课程名称、教师工号、教师姓名、学时、学分、学号、学生姓名添加时间等内容,还可在该页面进行编辑删除详细等操作,如图

5.2课程评价管理

在课程评价管理页面列表可查询评价信息:课程编号、课程名称、教师工号、教师姓名、学号、学生姓名、学生建议、添加时间等内容,还可在该页面进行编辑删除详细等操作,如图

六、部分核心代码

6.1登录代码

 /*** 登录* @param data* @param httpServletRequest* @return*/@PostMapping("login")public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {log.info("[执行登录接口]");String username = data.get("username");String email = data.get("email");String phone = data.get("phone");String password = data.get("password");List resultList = null;QueryWrapper wrapper = new QueryWrapper<User>();Map<String, String> map = new HashMap<>();if(username != null && "".equals(username) == false){map.put("username", username);resultList = service.selectBaseList(service.select(map, new HashMap<>()));}else if(email != null && "".equals(email) == false){map.put("email", email);resultList = service.selectBaseList(service.select(map, new HashMap<>()));}else if(phone != null && "".equals(phone) == false){map.put("phone", phone);resultList = service.selectBaseList(service.select(map, new HashMap<>()));}else{return error(30000, "账号或密码不能为空");}if (resultList == null || password == null) {return error(30000, "账号或密码不能为空");}//判断是否有这个用户if (resultList.size()<=0){return error(30000,"用户不存在");}User byUsername = (User) resultList.get(0);Map<String, String> groupMap = new HashMap<>();groupMap.put("name",byUsername.getUserGroup());List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));if (groupList.size()<1){return error(30000,"用户组不存在");}UserGroup userGroup = (UserGroup) groupList.get(0);//查询用户审核状态if (!StringUtils.isEmpty(userGroup.getSourceTable())){String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());if (res==null){return error(30000,"用户不存在");}if (!res.equals("已通过")){return error(30000,"该用户审核未通过");}}//查询用户状态if (byUsername.getState()!=1){return error(30000,"用户非可用状态,不能登录");}String md5password = service.encryption(password);if (byUsername.getPassword().equals(md5password)) {// 存储Token到数据库AccessToken accessToken = new AccessToken();accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));accessToken.setUser_id(byUsername.getUserId());tokenService.save(accessToken);// 返回用户信息JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));user.put("token", accessToken.getToken());JSONObject ret = new JSONObject();ret.put("obj",user);return success(ret);} else {return error(30000, "账号或密码不正确");}}public String select(Map<String,String> query,Map<String,String> config){StringBuffer sql = new StringBuffer("select ");sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");}if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");}if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);}log.info("[{}] - 查询操作,sql: {}",table,sql);return sql.toString();}public List selectBaseList(String select) {List<Map<String,Object>> mapList = baseMapper.selectBaseList(select);List<E> list = new ArrayList<>();for (Map<String,Object> map:mapList) {list.add(JSON.parseObject(JSON.toJSONString(map),eClass));}return list;}

6.2学生选课代码

@PostMapping("/add")@Transactionalpublic Map<String, Object> add(HttpServletRequest request) throws IOException {service.insert(service.readBody(request.getReader()));return success(1);}@Transactionalpublic Map<String, Object> addMap(Map<String,Object> map){service.insert(map);return success(1);}public Map<String,Object> readBody(BufferedReader reader){BufferedReader br = null;StringBuilder sb = new StringBuilder("");try{br = reader;String str;while ((str = br.readLine()) != null){sb.append(str);}br.close();String json = sb.toString();return JSONObject.parseObject(json, Map.class);}catch (IOException e){e.printStackTrace();}finally{if (null != br){try{br.close();}catch (IOException e){e.printStackTrace();}}}return null;}public void insert(Map<String,Object> body){StringBuffer sql = new StringBuffer("INSERT INTO ");sql.append("`").append(table).append("`").append(" (");for (Map.Entry<String,Object> entry:body.entrySet()){sql.append("`"+humpToLine(entry.getKey())+"`").append(",");}sql.deleteCharAt(sql.length()-1);sql.append(") VALUES (");for (Map.Entry<String,Object> entry:body.entrySet()){Object value = entry.getValue();if (value instanceof String){sql.append("'").append(entry.getValue()).append("'").append(",");}else {sql.append(entry.getValue()).append(",");}}sql.deleteCharAt(sql.length() - 1);sql.append(")");log.info("[{}] - 插入操作:{}",table,sql);Query query = runCountSql(sql.toString());query.executeUpdate();}

SpringBoot+Vue实现前后端分离的教务评教系统相关推荐

  1. SpringBoot+Vue实现前后端分离的校园外卖配送系统

    文末获取源码 开发语言:Java 使用框架:spring boot 前端技术:JavaScript.Vue.js .css3 开发工具:IDEA/MyEclipse/Eclipse.Visual St ...

  2. SpringBoot+vue实现前后端分离的餐厅点餐系统

    文末获取源码 开发语言:Java 开发工具:IDEA /Eclipse 数据库:MYSQL5.7 应用服务:Tomcat7/Tomcat8 使用框架:springboot+vue JDK版本:jdk1 ...

  3. SpringBoot+Vue实现前后端分离的餐饮点餐系统

    文末获取源码 开发语言:Java 使用框架:spring boot 前端技术:JavaScript.Vue.js .css3 开发工具:IDEA/MyEclipse/Eclipse.Visual St ...

  4. SpringBoot+Vue实现前后端分离的在线考试报名系统

    文末获取源码 开发语言:Java 使用框架:spring boot 前端技术:JavaScript.Vue.js .css3 开发工具:IDEA/MyEclipse/Eclipse.Visual St ...

  5. 视频教程-springboot+Vue整合前后端分离权限后台管理系统-Java

    springboot+Vue整合前后端分离权限后台管理系统 拥有八年的Java项目开发经验,擅长Java.vue.SpringBoot.springCloud.spring.springmvc.myb ...

  6. 基于SSM+SpringBoot+Vue+ElementUI前后端分离的校园岗位招聘就业管理系统

    运行视频 基于SSM+SpringBoot+Vue+ElementUI前后端分离的校园岗位招聘就业管理系统 项目运行截图 学生管理 添加学生 学生信息 教师管理 教师信息 实习基地 公告信息 公司管理 ...

  7. shiro+php,一套基于SpringBoot+Vue+Shiro 前后端分离 开发的代码生成器

    一.前言 最近花了一个月时间完成了一套基于Spring Boot+Vue+Shiro前后端分离的代码生成器,目前项目代码已基本完成 止步传统CRUD,进阶代码优化: 该项目可根据数据库字段动态生成 c ...

  8. springboot+vue的前后端分离与合并方案

    pringboot和vue结合的方案网络上的主要有以下两种: 1. [不推荐]在html中直接使用script标签引入vue和一些常用的组件,这种方式和以前传统的开发是一样的,只是可以很爽的使用vue ...

  9. 基于springboot+vue的前后端分离商城系统

    springboot前后端分离商城 介绍 springboot前后端分离商城 本项目由本人根据教程实现的一个springboot项目,基本已实现项目,但是本人希望加入自己的小功能, 请期待下一次的更新 ...

最新文章

  1. 沃丰报告:物联网的未来
  2. 牛气!GitHub 标星 119K+!这些神器仅需一行代码即可下载全网视频!
  3. java 文本编辑器 源码_java文本编辑器源码
  4. iref streams_如何利用Neo4j Streams并建立即时数据仓库
  5. NLP研究者必备的语言学书籍!
  6. 将z-blog改成英文blog所遇到的问题
  7. oracle 视图带条件,Oracle视图可以进行DML操作的条件
  8. 2019年11月数据库流行度排行:前三甲大幅下跌 PM 应云而升 国产续领风云
  9. python开发环境的安装与配置_Python开发环境的安装配置
  10. UI基础设计规范,确定不了解一下?
  11. 创业,一定要咬牙坚持吗?屁,该放就放
  12. Web API-DOM节点操作
  13. 南航计算机考研调剂,南京航空航天大学接受调剂生的时间定了,南航读研就业会咋样...
  14. U盘等无法弹出的解决办法
  15. C语言-学生成绩链表处理
  16. etcher制作linux启动盘,使用Etcher来创建可启动盘的方法
  17. Mysql导出数据库设计文档
  18. 内网渗透---ms14068
  19. C#窗口程序入口函数
  20. Unity3d用户手册用户攻略缓存效劳器常见疑问

热门文章

  1. 计算机结构化面试万能套话,结构化面试30句万能套话拯救你.pdf
  2. 阿尔法编程python答案_C语言程序设计-阿尔法编程(编程答案)
  3. LVGL (8) 绘制流程
  4. 颜色转换公式大全及转换表格(31种)
  5. 51单片机数码管循环显示0 9c语言,如何采用单片机实现数码管循环显示0-9
  6. unity3d英语单词拼写小游戏Pics Quiz Maker With Categories 3.0
  7. 视频垂直翻转播放的效果,如何同时制作多个视频
  8. 微信小程序wx.request封装
  9. Xcode 使用 code snippets (代码块)Xcode 11以上
  10. opencv实战案例之照片背景替换