基于SSM的在线考试系统

✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌

文末获取项目下载方式


一、项目背景介绍:

在线考试借助于网络来进行,传统考试所必备的考场和监考对于在线考试来说并不是必要项目,因此可以有效减少组织考试做需要的成本以及设施。同时,由于在线考试系统本身具有智能阅卷的功能,也大大减少了考试组织者在考试结束后阅卷集成绩统计所需要进行的工作。考生参加考试并不一定要被聚集在线下考场,而是可以使用电脑或手机等电子设备在任何场景参加考试。
  由于在线考试是在考试形式上发生了翻天覆地的变化,因此也会相对带来一系列的问题,比如在缺失考场和监考的环境下,如何保证成绩的真实性?这就需要借助于远程视频监控和考生桌面监控来解决了。

二、项目技术简介:

  1. JAVA:Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Spring:Spring框架是一个开放源代码的J2EE应用程序框架,由Rod Johnson发起,是针对bean的生命周期进行管理的轻量级容器(lightweight container)。 Spring解决了开发者在J2EE开发中遇到的许多常见的问题,提供了功能强大IOC、AOP及Web MVC等功能。Spring可以单独应用于构筑应用程序,也可以和Struts、Webwork、Tapestry等众多Web框架组合使用,并且可以与 Swing等桌面应用程序AP组合。因此, Spring不仅仅能应用于J2EE应用程序之中,也可以应用于桌面应用程序以及小应用程序之中。Spring框架主要由七部分组成,分别是 Spring Core、 Spring AOP、 Spring ORM、 Spring DAO、Spring Context、 Spring Web和 Spring Web MVC。
  3. Mybatis:MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github。
    iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAOs)。
  4. Jsp:JSP(全称JavaServer Pages)是由Sun Microsystems公司主导创建的一种动态网页技术标准。JSP部署于网络服务器上,可以响应客户端发送的请求,并根据请求内容动态地生成HTML、XML或其他格式文档的Web网页,然后返回给请求者。JSP技术以Java语言作为脚本语言,为用户的HTTP请求提供服务,并能与服务器上的其它Java程序共同处理复杂的业务需求。
    JSP将Java代码和特定变动内容嵌入到静态的页面中,实现以静态页面为模板,动态生成其中的部分内容。JSP引入了被称为“JSP动作”的XML标签,用来调用内建功能。另外,可以创建JSP标签库,然后像使用标准HTML或XML标签一样使用它们。标签库能增强功能和服务器性能,而且不受跨平台问题的限制。JSP文件在运行时会被其编译器转换成更原始的Servlet代码。JSP编译器可以把JSP文件编译成用Java代码写的Servlet,然后再由Java编译器来编译成能快速执行的二进制机器码,也可以直接编译成二进制码。
  5. Spring-Mvc:Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。使用 Spring 可插入的 MVC 架构,从而在使用Spring进行WEB开发时,可以选择使用Spring的Spring MVC框架或集成其他MVC开发框。
  6. Bootstrap:Bootstrap是美国Twitter公司的设计师Mark Otto和Jacob Thornton合作基于HTML、CSS、JavaScript 开发的简洁、直观、强悍的前端开发框架,使得 Web 开发更加快捷。Bootstrap提供了优雅的HTML和CSS规范,它即是由动态CSS语言Less写成。Bootstrap一经推出后颇受欢迎,一直是GitHub上的热门开源项目,包括NASA的MSNBC(微软全国广播公司)的Breaking News都使用了该项目。 国内一些移动开发者较为熟悉的框架,如WeX5前端开源框架等,也是基于Bootstrap源码进行性能优化而来。
  7. Html:HTML的全称为超文本标记语言,是一种标记语言。它包括一系列标签.通过这些标签可以将网络上的文档格式统一,使分散的Internet资源连接为一个逻辑整体。HTML文本是由HTML命令组成的描述性文本,HTML命令可以说明文字,图形、动画、声音、表格、链接等。

    超文本是一种组织信息的方式,它通过超级链接方法将文本中的文字、图表与其他信息媒体相关联。这些相互关联的信息媒体可能在同一文本中,也可能是其他文件,或是地理位置相距遥远的某台计算机上的文件。这种组织信息方式将分布在不同位置的信息资源用随机方式进行连接,为人们查找,检索信息提供方便。

三、系统功能模块介绍:

功能模块图

四、数据库设计:

1:admin(admin)

字段名 类型 默认值 列注释
id int NULL
name varchar NULL 姓名
number varchar NULL 工号
password varchar NULL 密码
role_id int NULL 角色id
last_login_time datetime NULL 最后登录时间

2:announce(announce)

字段名 类型 默认值 列注释
id int NULL
title varchar NULL 公告标题
content text NULL 公告内容
author_id varchar NULL 作者id
role_id int NULL 作者身份id:教师_3,管理员_1
author_name varchar NULL 作者名
create_time datetime NULL 公告创建时间

3:course(course)

字段名 类型 默认值 列注释
id int NULL
course_name varchar NULL
teacher_name varchar NULL 任课老师姓名
teacher_id int NULL 该门课的出题老师(默认一门课一个老师出题)

4:disk(disk)

字段名 类型 默认值 列注释
id int NULL
name varchar NULL 在网盘上看到的文件名
save_name varchar NULL 文件真实的名字
byte_size double NULL
p_id int NULL 父id
type varchar NULL 文件类型
create_time timestamp NULL
file_size varchar NULL
teacher_id int NULL
download_count int NULL
password varchar NULL
md5 varchar NULL

5:major(major)

字段名 类型 默认值 列注释
id int NULL
major varchar NULL 专业班级
academy varchar NULL 学院

6:paper(paper)

字段名 类型 默认值 列注释
id int NULL
paper_name varchar NULL 试卷名称
course_id int NULL 课程id
question_id varchar NULL 问题id组合
begin_time varchar NULL 试卷开始时间
end_time varchar NULL 试卷结束时间
allow_time varchar NULL 考试时长
score varchar NULL 试卷总分
paper_state varchar NULL 考试状态:未开始,进行中,已结束
paper_type varchar NULL 试卷类型:正式,模拟
major_id int NULL 专业班级id
paper_form_id int NULL 试卷组成id
teacher_id int NULL 出卷老师id

7:paper_form(paper_form)

字段名 类型 默认值 列注释
id int NULL
q_choice_num varchar NULL 单选题数目
q_choice_score varchar NULL 单选题分数
q_mul_choice_num varchar NULL 多选题数目
q_mul_choice_score varchar NULL 多选题分数
q_tof_num varchar NULL 判断题数目
q_tof_score varchar NULL 判断题分数
q_fill_num varchar NULL 填空题数目
q_fill_score varchar NULL 填空题分数
q_SAQ_num varchar NULL 简答题数目
q_SAQ_score varchar NULL 简答题分数
q_program_num varchar NULL 编程题数目
q_program_score varchar NULL 编程题分数

8:question(question)

字段名 类型 默认值 列注释
id int NULL
question_name text NULL 题目名称
option_a varchar NULL 选项a
option_b varchar NULL 选项b
option_c varchar NULL 选项c
option_d varchar NULL 选项d
type_id int NULL 题目类型id
answer text NULL 题目答案
course_id int NULL 课程id
difficulty varchar NULL 题目难度:容易,中等,较难
remark text NULL 题目解析

9:role(role)

字段名 类型 默认值 列注释
id int NULL 角色id:管理员_1,学生_2,老师_3
role_name varchar NULL 角色姓名

10:score(score)

字段名 类型 默认值 列注释
id int NULL
stu_id int NULL 考生id
paper_id int NULL 试卷id
paper_name varchar NULL 试卷名称
score varchar NULL 试卷分数
wrong_ids varchar NULL 错题id集合

11:stu_answer_record(stu_answer_record)

字段名 类型 默认值 列注释
id int NULL
paper_id int NULL 试卷id
stu_id int NULL 学生id
question_id int NULL 题目id
answer varchar NULL 题目答案

12:student(student)

字段名 类型 默认值 列注释
id int NULL
name varchar NULL 学生姓名
password varchar NULL 学生登录密码
stu_number varchar NULL 学号
major varchar NULL 专业班级
role_id int NULL 角色id
sex varchar NULL 性别

13:teacher(teacher)

字段名 类型 默认值 列注释
id int NULL
name varchar NULL 姓名
work_number varchar NULL 工号
password varchar NULL 密码
role_id int NULL 角色id
job varchar NULL 职位

14:type(type)

字段名 类型 默认值 列注释
id int NULL
type_name varchar NULL 题目类型
score varchar NULL 各个类型题目的分数
remark varchar NULL 该类型题目说明

五、功能模块:

  1. 用户登录:包含老师学生管理员登录

    用户登录

  2. 试题管理:教师可以通过添加试题丰富题库,也可以对已存在的题目进行修改和删除操作。

    试题管理

  3. 试卷管理:教师首先创建或选择试卷模版,系统会根据模版自动从题库中抽取题目进行组卷。

    试卷管理

  4. 试卷复查:考生的主观题答案会被保存到数据库中,教师可以对其进行复查。

    试卷复查

  5. 成绩统计分析:本系统可以根据特定课程或特定班级使用柱状图,折线图,数据罗列等方式帮助教师更直观得了解学生成绩情况。

    成绩统计分析

  6. 系统网盘:教师可以上传资料到网盘供学生下载学习

    系统网盘

  7. 学生-我的考试:学生进入后会看到试卷信息,当有需要参加的考试时,点击进入即可来到考试界面。
    考试结束系统会自动提交考卷并完成自动改卷任务。

    学生-我的考试

  8. 考试详情:考试详情

    考试详情

  9. 我的成绩:展示每门考试的成绩列表。

    我的成绩

  10. 成绩分析:系统会统计出该生本学期参加每门考试的成绩,以及该门课程的平均成绩,使用雷达图进行对比。

    成绩分析

六、代码示例:

 @Autowired
    private PaperService paperService;

    @GetMapping
    public String list(@RequestParam(name = "p", required = false, defaultValue = "1") Integer pageNo,
                       Model model, HttpSession session) {
        Integer teacherId = (Integer) session.getAttribute("teacherId");
        PageInfo<Paper> pageInfo = paperService.pageForPaperList(teacherId, pageNo);
        model.addAttribute("page", pageInfo);
        return "paper/list";
    }

    @GetMapping("/show/{id:\\d+}")
    public String show(@PathVariable Integer id, Model model) {
        Paper paper = paperService.findById(id);
        Course course = paperService.findCourseById(paper.getCourseId());
        Major major = paperService.findMajorById(paper.getMajorId());
        model.addAttribute("paper", paper);
        model.addAttribute("course", course);
        model.addAttribute("major", major);
        return "paper/show";
    }

    @GetMapping("/newPaperForm")
    public String addPaperForm() {
        return "paper/newPaperForm";
    }

    /**
     * 添加试卷组成模版
     * @param paperForm
     * @return
     */
    @PostMapping("/newPaperForm")
    public String addPaperForm(PaperForm paperForm) {
        paperService.newPaperForm(paperForm);
        return "redirect:/paper/newPaper/" + paperForm.getId();
    }

    /**
     * 添加试卷 组卷
     * @param model
     * @param id (paperForm的id,默认模版为1)
     * @param session
     * @return
     */
    @GetMapping("/newPaper/{id:\\d+}")
    public String add(Model model, @PathVariable Integer id, HttpSession session) {
        Integer teacherId = (Integer) session.getAttribute("teacherId");
        List<Course> courseList = paperService.findCourseListByTeacherId(teacherId);
        model.addAttribute("courseList", courseList);
        return "paper/newPaper";
    }

    @PostMapping("/newPaper/{paperFormId:\\d+}")
    public String add(Paper paper, @PathVariable("paperFormId") Integer paperFormId,
                      String major, RedirectAttributes redirectAttributes,
                      HttpSession session) {
        paper.setPaperFormId(paperFormId);
        Major majorObj = paperService.findMajorByMajorName(major);
        paper.setMajorId(majorObj.getId());
        try {
            paperService.newPaper(paper);
            return "redirect:/paper/show/" + paper.getId();
        } catch (ServiceException e) {
            e.printStackTrace();
            redirectAttributes.addFlashAttribute("message", e.getMessage());
            Teacher teacher = (Teacher) session.getAttribute("teacher");
            return "redirect:/teacher/home/" + teacher.getId();
        }

    }

    /**
     * 展示所有试卷模版列表
     * @param model
     * @return
     */
    @GetMapping("/showPaperForm")
    public String showPaperForm(Model model) {
        List<PaperForm> formList = paperService.findAllPaperForm();
        model.addAttribute("formList", formList);
        return "paper/showPaperForm";
    }

    /**
     * Ajax删除模版不跳转页面
     * @param id
     * @return
     */
    @GetMapping("/delPaperForm/{id:\\d+}")
    @ResponseBody
    public AjaxResult delPaperForm(@PathVariable Integer id) {
        try {
            paperService.delPaperFormById(id);
            return AjaxResult.success();
        } catch (Exception e) {
            return AjaxResult.error(e.getMessage());
        }

    }

    /**
     * 级联删除试卷、分数、答案记录
     * @param id
     * @return
     */
    @GetMapping("/delete/{id:\\d+}")
    public String delPaper(@PathVariable Integer id) {
        paperService.delPaperById(id);
        return "redirect:/paper";
    }

七、项目总结:

基于SSM的在线考试系统的整体功能模块的实现,主要是对自己在大学这几年时间所学内容的一个测试,对于系统,主要是通过现在智能化的基于SSM的在线考试系统进行开始系统的实现,经过一个学期的毕业设计的实现完成已接近尾声,到目前为止,当我回想起整个学期的系统开发日,收获颇丰。毕业设计的主要任务是建立一个智能化的基于SSM的在线考试系统 ,主要使用JAVA和Mysql数据库的开发工具,对系统的每个功能模块进行相对应的操作,最后,系统调试结果表明系统基本可以满足功能要求。

基于SSM的在线考试系统平台的开发对我大学学习的改进有很大帮助。它使我能够学习计算机知识的相关技术方面问题及与人交往的沟通交流方面,让我意识到无论我们做什么,我们都需要坚持不懈,努力工作,只有这样尝试了并且坚持去做了,我们才可以成功,才可以获得成功的喜悦,如果没有尝试,知识想,那连成功的机会都没有,实际操作进行做了,才会越来越近的靠近成功,随着道路一路向前,未来的路是美好的。对于驾校管理平台的实现,是自己第一次完成的设计一个管理系统。在项目的设计过程中,我克服了各种困难,并且在面对这些困难,我积极的面对,想办法解决问题,并且更好的掌握了理论知识和动手操作实践能力,从系统的开发到设计完成,我完成了一个更全面、更完善、更安全的平台管理系统,这也让我取得了很大的成就感,也使我对未来的生活更有信心。

八、源码获取:

大家点赞、收藏、关注、评论啦 、查看获取项目下载链接,博主联系方式

链接点击直达:下载链接

你可能感兴趣的:(优质毕业设计,java,ssm,考试)