毕业论文——SMART系统-考试监控及阅卷模块的设计与开发 (2)_第1页
毕业论文——SMART系统-考试监控及阅卷模块的设计与开发 (2)_第2页
毕业论文——SMART系统-考试监控及阅卷模块的设计与开发 (2)_第3页
毕业论文——SMART系统-考试监控及阅卷模块的设计与开发 (2)_第4页
毕业论文——SMART系统-考试监控及阅卷模块的设计与开发 (2)_第5页
已阅读5页,还剩21页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

分类号:分类号: U U D D C C: 密密 级:级: 编编 号:号: 成成 都都 信信 息息 工工 程程 学学 院院 学学 位位 论论 文文 SMARTSMART 系统系统- - 考试监控及阅卷模块的设计与开发考试监控及阅卷模块的设计与开发 SMARTSMART 系统系统 考试监控及阅卷模块的设计与开发考试监控及阅卷模块的设计与开发 摘摘 要要 Smart 在线考试评估系统(简称“SMART 系统”),是基于 Browser/Server(简称 B/S)结构的数据库访问模式,采用 Struts + Spring + Hibernate 作为平台搭建的框架开发的一套新型智能的远程教育软件。主要用 于各中小学的学生考试和教学评估。本论文设计作为 Smart 项目的一个组成部 分,主要实现了考试过程监控和客观题的自动阅卷功能。论文首先介绍了设计 中所涉及到的项目背景、开发技术,并构建了系统的总体框架;其次根据中小 学的实际情况和远程教育软件项目的需求,详细地进行了数据库设计和系统功 能模块设计,制定了各功能模块的流程图;然后采用 JAVA 编程语言对本论文的 设计任务进行编码,并最终实现了对考试过程的监控和对客观题的自动阅卷等 功能。通过本模块的应用,可以满足 SMART 系统的在线考试部分需求,对 SMART 系统的应用和发展起到一定的促进作用。 关键词关键词:Hibernate;在线考试;考试监控;阅卷 The SMART System Design and Implementation The Module of The Examination Controls and Paper Inspection Abstract Smart online examination and evaluation system, as SMART System for short; is a kind of the intelligent long-distance education software which is developed by the framework of the Struts + Spring + Hibernate. This system will be used mainly in the middle and primary schools for examination and evaluation. As the part of the system, it has mainly realized some functions, controlling the course of examination and looking over the papers automatically. First, the thesis introduces the background of the project and the technology that involved in the project, and the construction of the developing platform by according to the actual conditions of the elementary school and middle school. Second, according to the actual conditions of the middle schools and primary schools and the demand of the long-distance education software project, the thesis describes the designation of the database and the module of systematic function in details, and then makes the flow diagram of every function module; and then based upon JAVA language to program. At last the system provides the function of the examination controls and the automatic objective questions inspection. By this module applying, it may satisfy the Smart system demand, and promote the Smart system development. Key words: Hibernate; online examination; examination controls; paper inspection 目目 录录 论文总页数:23 页 1引言1 1.1课题背景1 1.2课题目的1 1.3课题意义1 2系统总体设计1 2.1系统构架及其相关技术介绍1 2.2开发环境及相关技术介绍5 3系统需求分析7 3.1考试监控模块需求分析7 3.2阅卷模块需求分析8 4系统数据库设计8 4.1考试监控模块数据库设计8 4.2阅卷模块数据库设计10 5系统功能设计及实现11 5.1考试监控模块设计及实现11 5.2阅卷模块设计及实现17 6系统测试19 结 论20 参考文献21 致 谢22 声 明23 第 1 页 共 23 页 1 1 引言引言 1.11.1 课题背景课题背景 随着计算机软硬件和互联网的发展,将传统的教育产业信息化成为可能。 但是目前学校与社会上的各种考试大都采用传统的考试方式,在此方式下,组 织一次考试至少要经过五个步骤,即人工出题、考生考试、人工阅卷、成绩评 估和试卷分析。显然,随着考试类型的不断增加及考试要求的不断提高,教师 的工作量将会越来越大,并且其工作将是一件十分烦琐和非常容易出错的事情, 可以说传统的考试方式已经不能适应现代考试的需要。所以拥有一套实用、完 善、高效的在线考试评估系统越来越显的重要。这样能更好的方便学校对教学 质量的管理,降低成本,提高效率。 1.21.2 课题目的课题目的 根据目前中小学的具体情况,设计一套符合他们的高效智能的在线考试评 估系统(SMART 在线考试系统) ,并为学校、主管部门教学评估、教学质量控制 提供决策依据。本课题主要实现该系统的部分功能考试监控及对客观题的 自动阅卷,从而减轻了老师的工作量。把更多的精力放入到对学生的教育中。 1.31.3 课题意义课题意义 SMART 在线考试评估系统(简称“SMART 系统” )目的是为中小学提供一个 公正客观的在线考试、在线评估的智能化平台。考试监控及对客观题的自动阅 卷的设计,主要是能够让老师平时繁琐的阅卷以及对整个考试过程的管理中解 脱出来,把更多的精力投入到对学生的教育中来;从而大大提高工作效率。与 此同时也提高了考试的质量,从而使考试更趋于公正、客观,更加激发学生的 学习兴趣。 2 2系统总体设计系统总体设计 2.12.1 系统构架系统构架及其相关技术介绍及其相关技术介绍 .1 系统构架系统构架 本系统是基于 Browser/Server(简称 B/S)结构的数据库访问模式,在 struts + spring 管理的 hibernate 作为平台框架搭建具体的 Smart 在线考试 评估系统。 采用 struts MVC 框架主要用于将 Smart 的数据流和业务流分开,采用 hibernate,主要用于更高效率对数据库存取效率及提高项目开发效率。采用 spring 管理的 hibernate 主要是获得 Spring 对 Hibernate 的支持,获得更高 的开发效率和更高的 Hibernate 操作性能。并能获得 Spring 相关的事务支持。 之所以不完全用 Spring 框架是考虑项目组的技术水平可能不足以完全驾驭这样 第 2 页 共 23 页 的框架规范。所以本系统不属于标准的 Struts + Spring + Hibernate 的标准 J2EE 应用。 对于 Hibernate 的数据库 IO 操作,将采用 DAO 模式将操作封装至 DAO 对象 中。而将建立专门的业务层,对 WEB 层及其他子模块或类进行接口。 如图 2-1 所示: 图 2-1系统框架结构图 .2 相关技术介绍相关技术介绍 三层 B/S 结构介绍 B/S 结构是真正的三层结构,它以访问 WEB 数据库为中心,HTTP 为传输协 议,客户端通过浏览器(Browser)访问 WEB 服务器和与其相连的后台数据库,我 们称之为 B/S(Browser/Server)模式。其三级结构组成如图 2-2 所示: 图 2-2B/S 三层结构图 图中从左到右,分为三个层次: 第一层是客户端即浏览器,主要完成客户和后台的交互及最终查询结果的 输出功能。在客户端向指定的 Web 服务器提出服务器请求,Web 服务器用 HTTP 协议把所需文件资料传给用户,客户端接受并显示在 WWW 浏览器上; 第二层 Web 服务器是功能层,完成客户的应用功能,即 Web 服务器接受客 户请求,并与后台数据库连接,进行申请处理,然后将处理结果返回 Web 服务 器,再传至客户端; 第三层数据库服务器是数据层。数据库服务器应客户请求独立地进行各种 处理。 与传统的 C/S 模式相比,B/S 结构把处理功能全部移植到了服务器端,用 客户端 WEB 服务器后台数据库 客户端 第 3 页 共 23 页 户的请求通过浏览器发出,无论是使用和数据库维护上都比传统模式更加经济 方便。而且使维护任务层次化:管理员负责服务器硬件日常管理和维护,系统 维护人员负责后台数据库数据更新维护。 由以上的分析可知,三层结构也可以理解为增加 WEB 服务器的 C/S 模式。 Struts Struts is 是 Apache Jakarta 项目的一部分,它用 Java Servlet/JavaServer Pages 技术,开发 Web 应用程序的开放源码的 framework。 Struts 有如下的主要功能: 1. 包含一个 controller servlet,能将用户的请求发送到相应的 Action 对象。 2. JSP 自由 tag 库,并且在 controller servlet 中提供关联支持,帮助 开发人员创建交互式表单应用。 3. 提供了一系列实用对象:XML 处理、通过 Java reflection APIs 自 动处理 JavaBeans 属性、国际化的提示和消息。 Struts 项目的目标是为创建 Java web 应用提供一个开放源代码的 framework。Struts framework 的内核是基于例如 Java Servlets, JavaBeans, ResourceBundles, 和 XML,以及各种 Jakarta Commons 包的标准技术的灵活 的控制层。 Struts 提供了它自身的控制器组件,并整合了其他技术,以提供模型和视 图。对于模型,同大多数的第三方软件包一样,如 Hibernate, iBATIS, 或者 Object Relational Bridge,Struts 能够和标准数据连接技术相结合,如 JDBC 和 EJB。对于视图,Struts 与 Java Server Pages 协同工作,包含 JSTL 和 JSF。 Spring Spring 框架是一个分层架构,由 7 个定义良好的模块组成。Spring 模块 构建在核心容器之上,核心容器定义了创建、配置和管理 bean 的方式,如图 2-3 所示: 第 4 页 共 23 页 图 2-3Spring 框架的 7 个模块图 组成 Spring 框架的每个模块(或组件)都可以单独存在,或者与其他一 个或多个模块联合实现。每个模块的功能如下: 核心容器:核心容器提供 Spring 框架的基本功能。核心容器的主要组 件是 BeanFactory,它是工厂模式的实现。BeanFactory 使用控制反转(IOC) 模式将应用程序的配置和依赖性规范与实际的应用程序代码分开。 Spring 上下文:Spring 上下文是一个配置文件,向 Spring 框架提供 上下文信息。Spring 上下文包括企业服务,例如 JNDI、EJB、电子邮件、国际 化、校验和调度功能。 Spring AOP:通过配置管理特性,Spring AOP 模块直接将面向方面的编 程功能集成到了 Spring 框架中。所以,可以很容易地使 Spring 框架管理的 任何对象支持 AOP。Spring AOP 模块为基于 Spring 的应用程序中的对象提供 了事务管理服务。通过使用 Spring AOP,不用依赖 EJB 组件,就可以将声明 性事务管理集成到应用程序中。 Spring DAO:JDBC DAO 抽象层提供了有意义的异常层次结构,可用该结 构来管理异常处理和不同数据库供应商抛出的错误消息。异常层次结构简化了 错误处理,并且极大地降低了需要编写的异常代码数量(例如打开和关闭连接) 。Spring DAO 的面向 JDBC 的异常遵从通用的 DAO 异常层次结构。 Spring ORM:Spring 框架插入了若干个 ORM 框架,从而提供了 ORM 的 对象关系工具,其中包括 JDO、Hibernate 和 iBatis SQL Map。所有这些都遵 从 Spring 的通用事务和 DAO 异常层次结构。 Spring Web 模块:Web 上下文模块建立在应用程序上下文模块之上,为 基于 Web 的应用程序提供了上下文。所以,Spring 框架支持与 Jakarta Struts 的集成。Web 模块还简化了处理多部分请求以及将请求参数绑定到 域 对象的工作。 Spring MVC 框架:MVC 框架是一个全功能的构建 Web 应用程序的 MVC 实现。通过策略接口,MVC 框架变成为高度可配置的,MVC 容纳了大量视图技 术,其中包括 JSP、Velocity、Tiles、iText 和 POI。 Hibernate Hibernate 是一个开放源代码的对象关系映射框架,它对JDBC 进 行了非常轻量级的对象封装,使得Java 程序员可以随心所欲的使用对 象编程思维来操纵数据库。 Hibernate 可以应用在任何使用JDBC 的 场合,既可以在Java 的客户端程序实用,也可以在Servlet/JSP 的 Web 应用中使用,最具革命意义的是,Hibernate 可以在应用 EJB 的 J2EE 架构中取代 CMP,完成数据持久化的重任。 第 5 页 共 23 页 2.22.2 开发环境及相关技术介绍开发环境及相关技术介绍 .1 开发环境开发环境 本设计主要运用 JSP 语言、Hibernate、Struts 等知识,在 Window Xp 的 环境下,采用 SQL Server2000 数据库,用 Eclipse3.2 + MyEclipse5.0 + Tomcat5.5 + j2sdk1.5 搭建 J2EE 开发环境进行开发。 .2 相关技术介绍相关技术介绍 JSP 介绍 JSP(Java Server Pages)是由 Sun Microsystems 公司倡导、许多公司参与 一起建立的一种动态网页技术标准,其网址为 /products/jsp。在传统的网页 HTML 文件 (*.htm,*.html)中加入 Java 程序片段(Scriptlet)和 JSP 标记(tag),就构成了 JSP 网页(*.jsp)。Web 服务器在遇到访问 JSP 网页的请求时,首先执行其中的 程序片段,然后将执行结果以 HTML 格式返回给客户。程序片段可以操作数据库、 重新定向网页以及发送 email 等等,这就是建立动态网站所需要的功能。所有 程序操作都在服务器端执行,网络上传送给客户端的仅是得到的结果,对客户 浏览器的要求最低,可以实现无 Plugin,无 ActiveX,无 Java Applet,甚至 无 Frame。 SQL Server2000 介绍 SQL Server 2000 是建立在 SQL Server 7.0 在可伸缩性、可用性、可管 理性和数据仓库成功的基础上,并且引入了针对电子商务的重要新功能。 在高性能和企业级可伸缩性领域,SQL Server 2000 设计成利用 Windows 2000 对更多处理器、更大的系统内存的支持,最终达到支持 64 位硬件平台。 在不断提升可用性的努力过程中,SQL Server 2000 采用 Windows 2000 四路 群集,提供了大大改进的群集支持。SQL Server 7.0 已经在可管理性和易用性 方面在行业内领先,SQL Server 2000 通过与 Windows 2000 活动目录紧密结 合进一步改进了这些功能。而且,SQL Server 2000 还包含对现有管理工具和 实用程序的重大改进,并引入更具自我调节和自我管理的引擎功能。 通过与 OLAP 服务、数据转换服务、存储库和英文查询的紧密结合,SQL Server 7.0 代表了行业内最全面的数据仓库和决策支持平台。SQL Server 2000 继续了这种创新,在整个系统内进行了重要的改进。特别重要的是,SQL Server 2000 关系引擎增加了实质化的视图,改善了在特大型数据库环境中执 行复杂查询的性能。同时,SQL Server 2000 引入了新的数据挖掘功能,可自 动发现在大量数据之间隐藏的关系并可基于历史数据做出预测。这些数据挖掘 功能将要实施,以向最终用户隐藏这种尖端技术的复杂性,并允许开发人员将 第 6 页 共 23 页 第三方的数据挖掘产品轻松集成进客户的应用程序中。最后,在电子商务领域, SQL Server 2000 高度集成了对 XML 和通过 Web 访问数据库的支持。 SQL Server 2000 按照设计可以为部署和维护强大的、易于管理、支持商 务活动的 Web 站点提供最好的性能,这些站点可以从事商家和商家之间或商家 与客户之间的交易。在寻求一个支持您的电子商务解决方案的数据库时,需要 考虑的项目包括:可用性、性能、可管理性和价格。 Eclipse 介绍 Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身 而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的 是,Eclipse 附带了一个标准的插件集,包括 Java 开发工具(Java Development Tools,JDT) 。 虽然大多数用户很乐于将 Eclipse 当作 Java IDE 来使用,但 Eclipse 的目标不仅限于此。Eclipse 还包括插件开发环境(Plug-in Development Environment,PDE) ,这个组件主要针对希望扩展 Eclipse 的软件开发人员, 因为它允许他们构建与 Eclipse 环境无缝集成的工具。由于 Eclipse 中的每 样东西都是插件,对于给 Eclipse 提供插件,以及给用户提供一致和统一的集 成开发环境而言,所有工具开发人员都具有同等的发挥场所。 这种平等和一致性并不仅限于 Java 开发工具。尽管 Eclipse 是使用 Java 语言开发的,但它的用途并不限于 Java 语言;例如,支持诸如 C/C+、COBOL 和 Eiffel 等编程语言的插件已经可用,或预计会推出。 Eclipse 框架还可用来 作为与软件开发无关的其他应用程序类型的基础,比如 内容管理系统。 基于 Eclipse 的应用程序的突出例子是 IBM 的 WebSphere Studio Workbench,它构成了 IBM Java 开发工具系列的基础。例如,WebSphere Studio Application Developer 添加了对 JSP、servlet、EJB、XML、Web 服 务和数据库访问的支持。 MyEclipse 介绍 MyEclipse 企业级工作平台(MyEclipse Enterprise Workbench ,简称 MyEclipse)是对 Eclipse 3.0 IDE 的扩展,利用它我们可以在数据库和 J2EE 的开发、发布,以及应用程序服务器的整合方面极大的提高工作效率。 Tomcat 介绍 Tomcat 是一个免费的开源的Serlvet 容器,它是 Apache 基金会的 Jakarta 项目中的一个核心项目,由Apache,Sun 和其它一些公司及个 人共同开发而成。由于有了Sun 的参与和支持,最新的Servlet 和 Jsp 第 7 页 共 23 页 规范总能在 Tomcat 中得到体现。 j2sdk 介绍 J2SDK=JDK+JRE,J2SDK(Java 2 Software Development Kit) JAVA2 软 件开发工具包,包括了 Java 编译器和 Java 虚拟器。 3 3系统需求分析系统需求分析 需求分析是一切工作的基础,他告诉我们将要做什么。只有当了解了所需 要做的任务后,才能对整个系统进行设计。 本课题主要实现 SMART 在线考试系统的部分功能-考试过程的监控及对客 观题的自动阅卷。 3.13.1 考试监控模块需求分析考试监控模块需求分析 考试监控模块的设计,主要是实现对学生参加考试的整个过程的设计及老 师对学生考试的监视与控制,包括查看学生信息,改变学生考试状态等。 学生要参加考试,必须根据学生的相关信息(如班级,学号,姓名等)以及当 前的服务器时间,来查找该生有权限参加的考试信息并显示在页面上。学生通过 点击相应的考试,进入到该门考试的答题界面。为了确保考试的有效性和安全 性,系统必须设定一下规则: (1).只有学生才能参加考试。 (2).学生在考试过程中,不能同时进行其他课程的考试。 (3).对学生来说,每一门考试只允许考一次;如果已经交卷,系统将会禁 止其重新进行考试。如果需要进行补考或者重考,教师可以另外设置一份考卷, 让学生进行考试。 为防止相邻学生之间可能会出现作弊的情况,要求在学生答题界面生成的 题目要随机排序。并且答题页面要禁止实用复制和右键功能。考虑到学生答题 过程中有可能会出现断线、死机、电脑故障等问题或者是要返回已经做过的题 目,要实现对学生做了的题目答案进行实时保存。当学生要查看已经做过的题 目时,要把题目的答案回调在页面上。 监控端主要涉及到对学生考试过程的管理。学生登陆系统时,要判断其是 迟到还是由于考试过程中异常情况而重登陆。如果是迟到,则该生的考试时间 不推迟,如果是由于考试过程中发生异常情况而造成的重登陆,则需要将学生 在重登陆系统所浪费的这个时间补偿给学生。 学生登陆系统时,都要将信息提交到监控端。监考老师可以通过监控页面 直观地看出学生的状态,并且可以改变其中的一个或多个学生的考试状态(如重 新考试,结束考试等),改变状态后,学生考试界面要出现相应的提示信息。 第 8 页 共 23 页 3.23.2 阅卷模块需求分析阅卷模块需求分析 传统的手工改卷,工作量既繁重又低效,出错的几率比较高。为了使学生 的考试更加趋向于公平公正,本模块主要实现对客观题的自动阅卷(如判断题、 多选题、单选题等) ,来代替传统的老师手工该卷。在学生主动提交考卷、老师 强制提交或者是考试结束时间到了自动提交后,要对学生当前的考试进行系统 自动阅卷,并统计出学生的各项大题分数和总分,为后面的评估做好基础。 学生考试结束后,如果试卷的组成都是客观题,则学生可以马上查看自己 的得分。 4 4 系统数据库设计系统数据库设计 数据库设计也是一个很重要的环节。设计一个合理的数据库,能够让程序 员在写代码的时候有很强的逻辑性,而不再为了理清数据库表间的关系浪费大 量的时间和精力。在以后的系统运行中,数据库也担当着重要的角色,不合理 的数据库往往是成为一个系统的瓶颈。 4.14.1 考试监控模块数据库设计考试监控模块数据库设计 此模块主要涉及到的数据库表有如下几张: 学生用户表: 表 4-1学生用户表(SMART_STUDENT) 学生用户表 SMART_STUDENT 字段名称数据类型是否是主键是否是外键是否可 NULL备注 Student_idDECIMAIL(18,0)YESNONO 自增 ID Student_noVARCHAR(50)NONONO 学生 NO UinVARCHAR(20)NONONOUIN student_nameVARCHAR(50)NONONO 学生姓名 Province_noVARCHAR(50)NONOYES 省 city_noVARCHAR(50)NONOYES 市 county_noVARCHAR(50)NONOYES 区/县 ref_school_noVARCHAR(50)NONOYES 学校 ref_grade_noVARCHAR(50)NONOYES 年级 ref_class_noVARCHAR(50)NONOYES 班级 Register_idBIGINTNONOYES 注册时的用户 ID TelVARCHAR(20)NONOYES 联系电话 e_mailVARCHAR(50)NONOYES E_Mail 地址 addressVARCHAR(100)NONOYES 地址信息 register_dateDATETIMENONOYES 注册时间 record_numberINTEGERNONONO 版本控制 remarkVARCHAR(100)NONOYES 备注 第 9 页 共 23 页 班级表: 表 4-2班级表(smart_class) 班级表 smart_class 字段名称数据类型是否是主键是否是外键是否可 NULL备注 class_idUNIQUEIDENTIFIERYESNONO 全球唯一码 Class_nameVARCHAR(50)NONONO 班级名字 class_noVARCHAR(50)NONONO 班级编号 class_noVARCHAR(2500)NONOYES 班级描述 lengthINTEGERNONOYES 编号长度 lastclass_noVARCHAR(50)NONOYES 上一级别编号 ruleclass_nameVARCHAR(50)NONOYES 设置的名称 lastnameVARCHAR(50)NONOYES 上级别名称 nextnameVARCHAR(50)NONOYES 下级别名称 record_numberINTEGERNONONO 版本控制 RemarkVARCHAR(100)NONOYES 备注 考试监控表: 表 4-3考试监控表(smart_exam_control) 考试监控表 smart_exam_control 字段名称数据类型是否是主键是否是外键是否可 NULL备注 control_idUNIQUEIDENTIFIERYESNONO全球唯一码 exam_nameVARCHAR(1000)NONONO考试名称 student_noVARCHAR(50)NONONO学生 NO student_nameVARCHAR(20)NONONO学生姓名 class_noVARCHAR(50)NONONO学生所在班级号 IpVARCHAR(50)NONOYES登陆 IP student_stateVARCHAR(20)NONONO学生状态 now_timeDARETIMENONONO写入时间 start_timeDARETIMENONONO考试开始时间 end_timeDARETIMENONONO考试结束时间 exam_delayDARETIMENONONO考试时长 landing_timeDARETIMENONONO登陆考试时间 submit_timeDARETIMENONONO提交考试时间 exam_tateVARCHAR(50)NONONO考试状态 record_numberINTEGERNONONO版本控制 RemarkVARCHAR(100)NONOYES备注 第 10 页 共 23 页 4.24.2 阅卷模块数据库设计阅卷模块数据库设计 此模块主要涉及到的数据库表有: 考试临时表: 表 4-4考试临时表(temp_smart_exam) 考试临时表 temp_smart_exam 字段名称数据类型 是否是主 键 是否是外 键 是否可 NULL 备注 Exam_temp_idUNIQUEIDENTIFIERYESNONO 全球唯一 码 exam_paper_noUNIQUEIDENTIFIERNONONO 试卷号 exam_paper_question_noVARCHAR(50)NONONO 试题号 exam_nameVARCHAR(50)NONONO 考试名 称 student_noVARCHAR(50)NONONO 学生 NO student_nameVARCHAR(20)NONONO 学生姓名 AnswerVARCHAR(50)NONOYES 试题答案 record_numberINTEGERNONONO 版本控制 RemarkVARCHAR(100)NONOYES 备注 考试结果表: 表 4-5考试结果表(smart_exam_result) 考试结果表 smart_exam_result 字段名称数据类型 是否是 主键 是否是 外键 是否可 NULL 备注 smart_exam_result_idUNIQUEIDENTIFIERYESNONO 全球唯一码 exam_paper_noUNIQUEIDENTIFIERNOYESNO 试卷号 exam_paper_question_noUNIQUEIDENTIFIERNOYESNO 试题号 exam_nameVARCHAR(50)NONONO 考试名称 student_noUNIQUEIDENTIFIERNOYESNO 学生 NO student_nameVARCHAR(20)NONONO 学生姓名 AnswerVARCHAR(50)NONOYES 试题答案 Is_rightINTEGERNONOYES 是否正确 ScoreFLOATNONOYES 试题得分 record_numberINTEGERNONONO 版本控制 RemarkVARCHAR(100)NONOYES 备注 第 11 页 共 23 页 考试结果统计表: 表 4-6考试结果统计表(smart_exam_stat_result) 考试结果统计表 smart_exam_stat_result 字段名称数据类型 是否是 主键 是否是 外键 是否可 NULL 备注 smart_exam_stat_result_idUNIQUEIDENTIFIERYESNONO 全球唯 一码 exam_paper_noUNIQUEIDENTIFIERNOYESNO 试卷号 exam_nameVARCHAR(50)NONONO 考试名 称 student_noUNIQUEIDENTIFIERNOYESNO 学生 NO student_nameVARCHAR(20)NONONO 学生姓 名 Single_choice_scoreFLOATNONoYES 单选题 得分 multi_choice_scoreFLOATNONOYES 多选题 得分 judgement_scoreFLOATNONOYES 判断题 得分 score_totalFLOATNONOYES 总分 record_numberINTEGERNONONO 版本控 制 RemarkVARCHAR(100)NONOYES 备注 5 5 系统功能设计及实现系统功能设计及实现 5.15.1 考试监控模块设计及实现考试监控模块设计及实现 考试监控模块的设计,是指对整个考试过程及考试过程中发生的一些事件 进行监视和控制。总体流程如下: 1. 学生在点击参加考试后,通过对学生所在的班级 NO 的判断,查找出所 有该班有权限参加的考试,再通过发卷时间与服务器当前时间的比对, 在页面上显示出符合该生的考试信息。 第 12 页 共 23 页 图 5-1学生考试信息图 主要实现代码: 通过用户登陆时写入 Session 的用户类型,判断是否是学生用户。如果是, 则通过用户 ID 查找到该用户对应的班级 NO,再通过班级 NO 查找对应的符合该 班级的考试信息。 /得到用户登陆是存在Session中的用户类型及用户ID Authorization user = (Authorization)request.getSession().getAttribute(Constants.USER_KEY); /用户ID Long userId = user.getLoginInfo().getUserId(); /用户类型 String userType = user.getLoginInfo().getType(); Map params = new HashMap(); SmartStudent entity = null; /判断该用户如果是学生类型,则将userID传到后台,通过SmartStudent试题得 到相关学生信息 if(userType.equals(UserType.STUDENT) params.put(“stuId“, userId); entity = (SmartStudent) this.call(new Carrier(params, BusinessConstants.PCM_USER_BUSINESS, “LoadStudent“); /得到学生所在班级NO String classNo = entity.getClassNo(); params = new HashMap(); /通过班级NO查找符合该班的考试信息 params.put(“classNo“, classNo); List result = (List) this.call(new Carrier(params, 第 13 页 共 23 页 BusinessConstants.EXAM_OPTION_BUSINESS, “SearchExam“); 比对服务器时间与考试发卷时间及考试结束时间,如果服务器时间早于发 卷时间或者迟于考试结束时间,则不显示该门的考试信息。 /调用DatetimeGap(String headDatetime, String tailDatetime)函数,返回两个日期时 /间字符串之间的差,日期尾减日期头,以秒为单位。 如果值为负数,说明日*期头大于日 /期尾,返回的格式为“long”。 SmartExam smartExam = (SmartExam)result.get(i); /得到考试发卷时间 String sendTime = smartExam.getSendTime().toString(); /得到考试结束时间 String endTime = smartExam.getEndTime().toString(); /格式化时间 DateFormat time = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss“); /获取服务器当前时间 String nowTime = time.format(new Date(); headDatetime - 日期头 格式为1999-10-10 12:12:12 tailDatetime - 日期尾 格式为1999-10-10 12:12:12 /将当前时间与考试发卷时间比较 long send = DateUtil.getDatetimeGap(sendTime.toString(),nowTime.toString(); /将当前时间与考试结束时间比较 long end = DateUtil.getDatetimeGap(endTime.toString(),nowTime.toString() ; if(send 0) else /如果当前时间在发卷时间和考试结束时间内,则将smartExam内的元素写入到resultList resultList.add(smartExam); /写入session request.getSession().setAttribute(“resultList“, resultList); 2.学生通过点击对应的考试进入考试界面(此时将学生的信息,如姓名、 学号、登陆时间、登陆 IP 等写入监控表) ,进行答题。 图 5-2学生考试答题图 第 14 页 共 23 页 学生考试过程中要定时的获取服务器时间(比如 10 秒),再将该时间写入监 控表,服务器端也要每隔一段时间去读取监控表内的该时间,如果该时间很久 没有刷新,则说明此时考试端可能出现了异常情况(如掉线、死机等) 。这样就 方便管理员去管理学生考试。流程图如下: 用户考试端获取服务器时间并写监控表流程图: 用户考试端 是否在考试时间 内 读取服务器时 间 YES NO考试结束 开始考试 写入监控表 图 5-3用户考试端获取并写监控表流程图 用户监控端读取监控表流程图: 用户监控端 读取监控表 是否在考试时间 内 YES NO考试结束 开始监控 返回处理结 果 图 5-4用户监控端读取监控表流程图 3. 监控端监考老师可以选择一个或多个班级进行监控。通过选择班级后, 将这些班级的所有参加当前考试的学生信息罗列出来,监考老师可以对学生进 行相应的操作。 具体实现: 监考老师可以直接选择要监控的班级,或者也可以通过年级查询先过滤一 些年级再进行操作。点击确定后跳到对应班级的所有学生的监控页面。 第 15 页 共 23 页 图 5-5用户监控端班级列表图 监考老师可以实时获得各个学生的考试状态。也可以对某个或多个学生进 行对应的考试操作,如让他们重新考试或者是结束考试等。 图 5-6用户监控端监控页面图 用户监控端改变考试状态流程图: 用户监控端 是否在考试时间 内 YES YES NO 是否改变学生考 试状态 NO 考试结束 写入监控表 开始监控 图 5-7用户监控端改变考试状态流程图 第 16 页 共 23 页 用户考试端获取考试状态流程图: 用户考试端 读取监控表 是否在考试时间 内 YES NO 状态是否改变 YES NO 返回处理结果 考试结束 开始考试 图 5-8用户考试端获取考试状态流程图 具体实现方法: /创建 XMLHttpRequest 类 var xmlHttp; function createXMLHttpRequestObject() if(window.ActiveXObject) xmlHttp=new ActiveXObject(“Microsoft.XMLHTTP“); else if(window.XMLHttpRequest) xmlHttp=new XMLHttpRequest(); /向服务器发送请求 function startRequest(url,functionName) /url 为要执行的在 action 中的更新方法 var url = “/examPageAction.do?action=update“; createXMLHttpRequestObject(); /发送请求后的回调函数 / getExamState为我要调用的javascript函数名(主要实现对各种状态的处理) xmlHttp.onreadystatechange=getExamState; xmlHttp.open(“GET“,url,true); /发送请求并异步执行 xmlHttp.send(null); /实现的 javascript 代码 function getExamState() if (xmlHttp.readyState = 4 var state = examState0.firstChild.nodeValue; /对不同的状态进行不同的操作 if(state = kaoshizhong) if(state = kaoshihou) if(state = kaoshiqian) 第 17 页 共 23 页 /定时调用该函数,时间单位为毫秒 window.setInterval(“startRequest()“, 10000); 如老师禁止学生考试,则在学生考试端显示相关的信息。学生确认消息后 则自动退出当前考试。 图 5-9用户考试端 状态被改变后的答题页面 5.25.2 阅卷模块设计及实现阅卷模块设计及实现 在学生主动提交考卷、老师强制提交或者是考试时间到了自动提交后,对 存在考试临时表内的学生试题信息进行判断,并将结果存入到考试结果表中。 最后将分数进行统计存到考试结果统计表中。 其中涉及到的表主要有 3 张:考试临时表,考试结果表和考试结果统计表。 关系如图 5-10 所示: 图 5-10 阅卷相关表与其他表间的关系图 第 18 页 共 23 页 自动阅卷流程如图 5-11 所示: 考试结果统 计表 考试结果表考试临时表自动阅卷分数统计开始阅卷结束阅卷 图 5-11 阅卷流程图 具体实现: /构造实体类 public class SmartExamTemp extends PersistenceObject implements Audit, java.io.Serializable /接口 public class SmartExamTempImpl extends AbstractDAO implements SmartExamTempDAO public List search(String no) /在 Business 中调用 public class SmartExamTempBusiness extends BaseBusiness public Object process search(Carrier vo) /在 action 中调用 public class ExamControlAction extends BaseAction public ActionForward save(ActionMapping mapping, ActionForm form, HttpServletReq

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论