1.1 开发背景
在线考试系统的设计与实现,首先需要对系统进行需求分析,明确系统的功能和性能要求。系统需要具备考试管理、题库管理、在线考试、自动阅卷等功能,同时还需要保证系统的安全性、稳定性和可扩展性。
在系统的架构设计方面,可以采用C/S或B/S模式。对于C/S模式,服务器端负责数据的管理和存储,客户端负责用户交互和数据展示。对于B/S模式,客户端采用浏览器访问,无需安装其他软件,方便用户使用。根据实际情况,可以选择适合的模式进行设计。
系统的功能模块包括用户管理、题库管理、考试管理、在线考试、成绩查询等。其中,用户管理模块负责管理用户信息,包括用户注册、登录、权限管理等;题库管理模块负责试题的添加、修改、删除等操作;考试管理模块负责考试安排、考试监控等;在线考试模块提供在线考试功能,支持多种题型;成绩查询模块提供成绩查询功能。
在系统的实现方面,可以采用多种编程语言和技术进行开发。常用的技术包括数据库技术、Web技术、网络通信技术等。数据库技术用于存储和管理数据,Web技术用于构建用户界面和实现交互功能,网络通信技术用于实现客户端与服务器之间的通信。
1.2 开发意义
随着社会的高速发展,人们生活水平的不断提高,以及教职工工作节奏的加快,线上考试逐渐成为一个热门的话题,为缓解教职工手动批改试卷的繁重压力,故学生考试系统的信息化成为首要选择。
我国的计算机技术诞生于20世纪40年代,起步晚但是发展非常迅速,虽然把计算机引入管理的领域也就只有短短的30年,但是,却给管理领域带来了翻天覆地的变化。伴随计算机的普及,人们也愿意并习惯通过计算机来获取信息资源,人们可以在最短的时间内获取最新数据信息,大大的节省自己的时间、精力,获得最大限度的身心满足。
传统的管理方法采用的是人管理人的方法,由相关人员去制定一些规定 并监督执行,这当然会给管理带来很多的主观性,而传统的考试管理也是采用人力的自然管理和纸制记录。在查询,更新时都是由人一条一条的记录,这样不仅需要大量的人力还需要大量的办公用品。这必然造成对人力和物力的浪费,而且由于工作量大并且繁琐,就会带来效率方面的低下,而这些就会无形地加重教职工的工作压力。
在线考试系统正是在这样的背景下应运而生了。现实的要求是在线考试系统需要一个既可以节省人力物力又可以节省财力,并且在同等时间的基础上提高效率,从而提高学校整体教学水平。在线考试系统采取的是信息分类管理的理念,根据学生考试所涉及的方方面面的具体要求进行系统开发的。
2.1 系统的需求分析
本系统需满足以下几个方面的要求:
- 账号权限管理,分为管理员账号,教师账号,普通用户(学生)账号。
- 题库管理界面。
- 试题管理界面。
- 题库管理界面。
- 阅卷管理界面。
- 在线考试界面。
- 我的成绩界面。
- 我的题库界面。
- 考试统计界面。
- 公告管理界面。
- 角色管理界面。
- 用户管理界面。
- 注册界面。
2.2 系统开发设计思想
系统采用前后端分离技术,既便于系统功能的各种组合和修改,又便于未参与开发的技术维护人员补充、维护;
系统应具备数据库维护功能,及时根据用户需求进行数据的添加、删除、修改、备份等操作。
2.4.2 springboot简介
SpringBoot是一种全新的框架,目的是为了简化Spring应用的初始搭建以及开发过程。该框架使用特定的方式(集成starter,约定优于配置)来进行配置,从而使开发人员不需要再定义样板化的配置。SpringBoot提供了一种新的编程范式,可以更加快速便捷地开发Spring项目,在开发过程当中可以专注于应用程序本身的功能开发,而无需在Spring配置上花太大的工夫。
SpringBoot基于Sring4进行设计,继承了原有Spring框架的优秀基因。SpringBoot并不是一个框架,而是一些类库的集合。maven或者gradle项目导入相应依赖即可使用SpringBoot,而无需自行管理这些类库的版本。
2.4.3 springboot优点
1、为基于Spring的项目开发提供更快捷的入门体验:特别是对于刚开始使用Spring框架的开发人员,无需关心使用Spring框架都需要引入哪些jar包,无需关心Spring框架与其他框架整合时都需要哪些配置文件。SpringBoot会自动配置Spring。
2、无需手动管理依赖jar包的版本:SringBoot通过 spring boot starter管理其提供的所有依赖的版本,当升级SpringBoot时,这些依赖的版本也会随之升级,个人无需指定版本号,但是也可以自定义版本号覆盖SpringBoot的默认值。
3、自动配置,无需XML:SpringBoot尝试根据你添加的jar依赖自动配置你的应用。
4、嵌入式的Tomcat,无需部署war文件。传统的项目我们在启动或者部署的时候,需要将项目的war包放到服务器(如Tomcat、JBoss)的指定目录下,然后再启动服务器。而SpringBoot项目在启动时无需将war文件部署到服务器中。SpringBoot内置了Tomcat和Jetty容器。在服务器启动SpringBoot项目时可以通过jar指令直接启动, 在开发IDE中启动时只需运行Application类的main方法即可。
5、简化Maven配置:SpringBoot通过 spring boot starter管理jar包,无需手动配置jar包的版本。之前我们在进行jar包配置时,需要找到jar包的版本号,而在SpringBoot项目中,则无需去管理版本号。
2.4.4 vue简介
vue是一套构建用户界面的框架。在我看来,渐进式代表的含义是:主张最少。每个框架都不可避免会有自己的一些特点,从而会对使用者有一定的要求,这些要求就是主张,主张有强有弱,它的强势程度会影响在业务开发中的使用方式。简单说就是对于vue中你不熟悉不太把握的模块或者功能,你可以不用它,或者你可以用你熟悉有把握的技术进行代替 。这样子看来是不是感觉很友好,相对于其他框架硬要求很少了,你可以逐渐性的使用框架。
为了实现前后端分离的开发理念,开发前端 SPA(single page web application) 项目,实现数据绑定,路由配置,项目编译打包等一系列工作的技术框架。
Vue有著名的全家桶系列,包含了vue-router(http://router.vuejs.org),vuex(http://vuex.vuejs.org), vue-resource(https://github.com/pagekit/vue-resource)。再加上构建工具vue-cli,sass样式,就是一个完整的vue项目的核心构成。
2.4.5 vue优点
1、轻量级框架
只关注视图层,是一个构建数据的视图集合,大小只有几十kb
Vue.js通过简洁的API提供高效的数据绑定和灵活的组件系统
2、简单易学
国人开发,中文文档,不存在语言障碍,易于理解和学习。
3、双向数据绑定
也就是所谓的响应式数据绑定。这里的响应式不是@media 媒体查询中的响应式布局,而是指vue.js会自动对页面中某些数据的变化做出同步的响应。
也就是说,vue.js会自动响应数据的变化情况,并且根据用户在代码中预先写好的绑定关系,对所有绑定在一起的数据和视图内容都进行修改。而这种绑定关系,就是以input 标签的v-model属性来声明的,因此你在别的地方可能也会看到有人粗略的称vue.js为声明式渲染的模版引擎。
这也就是vue.js最大的优点,通过MVVM思想实现数据的双向绑定,让开发者不用再操作dom对象,有更多的时间去思考业务逻辑。
4、组件化
在前端应用,我们是否也可以像编程一样把模块封装呢?这就引入了组件化开发的思想。
Vue.js通过组件,把一个单页应用中的各种模块拆分到一个一个单独的组件(component)中,我们只要先在父级应用中写好各种组件标签(占坑),并且在组件标签中写好要传入组件的参数(就像给函数传入参数一样,这个参数叫做组件的属性),然后再分别写好各种组件的实现(填坑),然后整个应用就算做完了。
5、视图,数据,结构分离
使数据的更改更为简单,不需要进行逻辑代码的修改,只需要操作数据就能完成相关操作
6、虚拟DOM
现在的网速越来越快了,很多人家里都是几十甚至上百M的光纤,手机也是4G起步了,按道理一个网页才几百K,而且浏览器本身还会缓存很多资源文件,那么几十M的光纤为什么打开一个之前已经打开过,已经有缓存的页面还是感觉很慢呢?这就是因为浏览器本身处理DOM也是有性能瓶颈的,尤其是在传统开发中,用JQuery或者原生的JavaScript DOM操作函数对DOM进行频繁操作的时候,浏览器要不停的渲染新的DOM树,导致页面看起来非常卡顿。
而Virtual DOM则是虚拟DOM的英文,简单来说,他就是一种可以预先通过JavaScript进行各种计算,把最终的DOM操作计算出来并优化,由于这个DOM操作属于预处理操作,并没有真实的操作DOM,所以叫做虚拟DOM。最后在计算完毕才真正将DOM操作提交,将DOM操作变化反映到DOM树上。
7、运行速度更快
像比较与react而言,同样都是操作虚拟dom,就性能而言,vue存在很大的优势。
2.4.6 redis简介
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
Redis是一个Key-Value存储系统,和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及其交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,Redis支持各种不同方式的排序。与Memcached一样,为了保证效率,数据都是缓存在内存中。Redis是一个高性能的Key-Value数据库。
2.4.7 redis优点
1. 高性能:Redis将数据存储在内存中,因此读写速度非常快,适用于对性能 要求较高的场景。
2. 支持丰富的数据结构:Redis支持字符串、哈希表、列表、集合、有序集合 等多种数据结构,使得它可以灵活地应对各种数据处理需求。
持久化支持:Redis支持将数据持久化到磁盘,可以在重启后恢复数据,保证数 据的可靠性。
- 高可用性:Redis支持主从复制和哨兵机制,可以实现数据的自动备份和故障转移,提高系统的可用性。
- 分布式支持:Redis Cluster可以将数据分布在多个节点上,实现数据的分片和负载均衡,提高系统的扩展性和容错性。
- 丰富的特性:除了支持丰富的数据结构外,还支持键过期功能、发布/订阅功能、事务功能、管道功能、Lua脚本功能、集群分片和数据复制功能等。
- 丰富的客户端:Redis有各种各样的客户端支持,包括所有的主流开发语言。
3.2 系统功能模块的划分
软件所实现的功能强弱是衡量一个软件的最根本的标准。经过对系统的需求分析和实际应用需求,确定了本子系统的功能模块如图3.2所示:
图3.2 系统功能模块图
4.1主要界面实现
本系统的UI设计主要采用ElementUI,使得界面更加大气美观。
4.1.1用户登录
4.1.1.1 登录
输入正确的用户名、密码后进行登录。
4.1.1.2 注册
输入正确的用户名、密码、确认密码后进行注册。
4.1.2 首页
登录成功后进入首页面。
4.1.3 题库管理
教师登录系统后,可进行【题库管理】的操作,题库管理列表如下图。
如需项目源码与文档请私信!!