SpringBoot+Vue实现软件工程课程在线考试系统

博主主页:一季春秋
博主简介:专注Java技术领域和毕业设计项目实战、Java、微信小程序、安卓等技术开发,远程调试部署、代码讲解、文档指导、ppt制作等技术指导。
主要内容:毕业设计(Java项目、小程序等)、简历模板、学习资料、面试题库、技术咨询。
文末联系获取

 一、项目介绍

软件工程课程在线考试系统主要功能模块包括首页、资源管理(在线考试)、系统用户(管理员、学生用户、教师用户)、模块管理(班级信息),采取面对对象的开发模式进行软件的开发和硬体的架设,能很好的满足实际使用的需求,完善了对应的软体架设以及程序编码的工作,采取MySQL作为后台数据的主要存储单元,采用springboot框架、Java技术技术进行业务系统的编码及其开发,实现了本系统的全部功能。 

二、项目主要技术 

开发语言:Java

使用框架:spring boot

前端技术:JavaScript、Vue 、css3

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

数据库:MySQL 5.7/8.0

数据库管理工具:phpstudy/Navicat

JDK版本:jdk1.8

Maven: apache-maven 3.8.1-bin

 三、系统功能

本系统使用的角色大概分为学生、教师和管理员。 

3.1学生需求

学生登陆系统主要进行三类操作:在线考试,成绩查询与个人信息管理。

 (1)在线考试

系统能自动给学生选题,考题必须是随机分配的,以保证考试的公平性。学生在考试过程中页面将提供考试时间倒计时功能,使学生随时了解考试剩余时间。在考试时间到时,系统将自动地将学生考试试卷提交,将提醒学生离开考场。当考试试卷提交时,教师为学生提交的答卷进行评分。

(2)成绩查询与个人信息维护

学生可以登陆系统查询各科成绩,其中成绩信息包括每种题型的得分,如单选题,判断题等。别外学生还可以查询自己的做错的题目,了解自己的考试情况。

除此之外,学生登陆系统可以查看和修改个人的基本信息,如修改密码等。 

3.2管理员需求 

系统管理员登陆系统后主要进行四类操作:

(1)在线考试信息的维护

在线考试信息的维护主要是对于学生提交的答卷信息、评分信息、题库信息进行维护。

(2)用户维护

系统管理员可以对用户信息(包括学生信息)进行增,删,改查操作。

(3)个人信息维护

管理员也可以对自己的基本信息的维护。

(4)班级信息维护

管理员管理和维护班级信息。

 3.3教师需求

教师登陆系统后主要进行三类操作:

(1)在线考试

在线考试主要是对于学生提交的答卷进行评分、添加题库等。

(2)个人信息维护

教师可以查看和修改个人的基本信息,如修改密码等。

(3)班级信息

管理员可以查看班级信息。

  

四、系统论文参考

  

五、项目功能截图 

用户登录界面

  

答题界面 

  

查看评分信息界面 

  

教师在线考试界面

 

题库界面 

学生用户界面 

班级信息界面 

六、代码实现 

/**
     * 登录
     * @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;
        Map<String, String> map = new HashMap<>();
        if(username != null && "".equals(username) == false){
            map.put("username", username);
            resultList = service.select(map, new HashMap<>()).getResultList();
        }
        else if(email != null && "".equals(email) == false){
            map.put("email", email);
            resultList = service.select(map, new HashMap<>()).getResultList();
        }
        else if(phone != null && "".equals(phone) == false){
            map.put("phone", phone);
            resultList = service.select(map, new HashMap<>()).getResultList();
        }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.select(groupMap, new HashMap<>()).getResultList();
        if (groupList.size()<1){
            return error(30000,"用户组不存在");
        }

        UserGroup userGroup = (UserGroup) groupList.get(0);

        //查询用户审核状态
        if (!StringUtils.isEmpty(userGroup.getSourceTable())){
            String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();
            String res = String.valueOf(service.runCountSql(sql).getSingleResult());
            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, "账号或密码不正确");
        }
}
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在线考试课程设计说明书的实现可以通过Spring Boot和Vue来完成。以下是具体的分步说明: 1. 后端设计(Spring Boot): - 使用Spring Boot框架搭建后端应用程序。 - 配置数据库连接,可以使用MySQL或其他关系型数据库。 - 创建实体类,包括考试考试题目、考试记录等。 - 使用Spring Data JPA实现数据库操作,包括增删改查等。 - 编写数据访问层接口和服务层实现,处理与数据库的交互。 - 实现RESTful API,提供接口供前端调用,包括题目获取、考试记录提交等。 - 使用Spring Security进行用户认证和权限控制,确保只有授权用户可以进行考试。 2. 前端设计(Vue): - 使用Vue框架搭建前端应用程序。 - 设计考试界面,包括考试信息展示、答题区域等。 - 使用Vue Router实现路由功能,进行页面的跳转和导航。 - 使用Vuex进行状态管理,例如保存用户信息、考试记录等。 - 通过异步请求获取后端提供的题目数据,并展示在界面上。 - 实现答题功能,包括选择题、填空题、简答题等。 - 配置页面验证,确保答题格式的正确性。 - 实现考试提交功能,将用户答题结果发送到后端保存。 3. 其他功能: - 数据库设计:根据考试的需求,设计数据库表结构,包括考试信息、题目信息、考试记录等。 - 安全性设计:使用HTTPS协议保证数据传输的安全性,对用户信息进行加密存储。 - 优化和调试:对系统进行性能优化,确保系统的稳定性和可靠性。 - 日志记录:记录用户的考试行为和答题结果,方便后续的统计和分析。 使用Spring Boot和Vue实现在线考试课程设计说明书,可以使系统具有后端和前端分离的特点,提升开发效率并增加系统的可维护性。同时,Spring Boot和Vue都具有丰富的生态圈和社区支持,可以方便地扩展和添加新功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一季春秋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值