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

发布于:2024-05-05 ⋅ 阅读:(28) ⋅ 点赞:(0)
一、前言介绍

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

教务评教系统使用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")
 
    @Transactional
 
    public Map<String, Object> add(HttpServletRequest request) throws IOException {
 
        service.insert(service.readBody(request.getReader()));
 
        return success(1);
 
    }
 
    @Transactional
 
    public 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();
 
    }

 

此源码非开源,若需要此源码可扫码添加微信或者qq:2214904953进行咨询!

2600多套项目欢迎咨询