




已阅读5页,还剩22页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
分类号:TP311.1 U D C:D10621-408-(2007)5996-0密 级:公 开 编 号:2003032122成 都 信 息 工 程 学 院学 位 论 文SMART 系统-考试监控及阅卷模块的设计与开发论文作者姓名: 黄孝国申请学位专业: 网络工程申请学位类别: 工学学士指导教师姓名(职称): 李谊瑞(研究员)论文提交日期: 2007年6月5日SMART 系统考试监控及阅卷模块的设计与开发摘 要Smart 在线考试评估系统(简称“SMART 系统”),是基于 Browser/Server(简称 B/S)结构的数据库访问模式,采用 Struts + Spring + Hibernate 作为平台搭建的框架开发的一套新型智能的远程教育软件。主要用于各中小学的学生考试和教学评估。本论文设计作为 Smart项目的一个组成部分,主要实现了考试过程监控和客观题的自动阅卷功能。论文首先介绍了设计中所涉及到的项目背景、开发技术,并构建了系统的总体框架;其次根据中小学的实际情况和远程教育软件项目的需求,详细地进行了数据库设计和系统功能模块设计,制定了各功能模块的流程图;然后采用JAVA编程语言对本论文的设计任务进行编码,并最终实现了对考试过程的监控和对客观题的自动阅卷等功能。通过本模块的应用,可以满足 SMART系统的在线考试部分需求,对 SMART 系统的应用和发展起到一定的促进作用。关键词:Hibernate;在线考试;考试监控;阅卷TheSMARTSystemDesignandImplementationTheModuleofTheExaminationControlsandPaperInspectionAbstractSmart online examination and evaluation system, as SMART System for short;is a kind of the intelligent long-distance education software which is developed bythe framework of the Struts + Spring + Hibernate. This system will be used mainlyinthe middleand primary schools for examinationand evaluation.Asthe part of thesystem, it has mainly realized some functions, controlling the course of examinationand looking over the papers automatically. First, the thesis introduces thebackground of the project and the technology that involved in the project, and theconstruction of the developing platform by according to the actual conditions of theelementary school and middle school. Second, according to the actual conditions ofthe middle schools and primary schools and the demand of the long-distanceeducation software project, the thesis describes the designation of the database andthe module of systematic function in details, and then makes the flow diagram ofevery function module; and then based upon JAVAlanguage to program.At last thesystemprovidesthefunctionoftheexaminationcontrolsandtheautomaticobjectivequestions inspection. By this module applying, it may satisfy the Smart systemdemand,andpromotetheSmartsystemdevelopment.Key words: Hibernate; online examination; examination controls; paperinspection目 录 论文总页数:23页1 引言.11.1 课题背景.11.2 课题目的.11.3 课题意义.12 系统总体设计.12.1 系统构架及其相关技术介绍.12.2 开发环境及相关技术介绍.53 系统需求分析.73.1 考试监控模块需求分析.73.2 阅卷模块需求分析.84 系统数据库设计.84.1 考试监控模块数据库设计.84.2 阅卷模块数据库设计.105 系统功能设计及实现.115.1 考试监控模块设计及实现.115.2 阅卷模块设计及实现.176 系统测试.19结 论.20参考文献.21致 谢.22声 明.23第 1 页 共 23 页1 引言1.1 课题背景随着计算机软硬件和互联网的发展,将传统的教育产业信息化成为可能。但是目前学校与社会上的各种考试大都采用传统的考试方式,在此方式下,组织一次考试至少要经过五个步骤,即人工出题、考生考试、人工阅卷、成绩评估和试卷分析。显然,随着考试类型的不断增加及考试要求的不断提高,教师的工作量将会越来越大,并且其工作将是一件十分烦琐和非常容易出错的事情,可以说传统的考试方式已经不能适应现代考试的需要。所以拥有一套实用、完善、高效的在线考试评估系统越来越显的重要。这样能更好的方便学校对教学质量的管理,降低成本,提高效率。1.2 课题目的根据目前中小学的具体情况,设计一套符合他们的高效智能的在线考试评估系统(SMART在线考试系统),并为学校、主管部门教学评估、教学质量控制提供决策依据。本课题主要实现该系统的部分功能考试监控及对客观题的自动阅卷,从而减轻了老师的工作量。把更多的精力放入到对学生的教育中。1.3 课题意义SMART在线考试评估系统(简称“SMART系统”)目的是为中小学提供一个公正客观的在线考试、在线评估的智能化平台。考试监控及对客观题的自动阅卷的设计,主要是能够让老师平时繁琐的阅卷以及对整个考试过程的管理中解脱出来,把更多的精力投入到对学生的教育中来;从而大大提高工作效率。与此同时也提高了考试的质量,从而使考试更趋于公正、客观,更加激发学生的学习兴趣。2 系统总体设计2.1 系统构架及其相关技术介绍2.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.1.2 相关技术介绍 三层B/S结构介绍B/S结构是真正的三层结构,它以访问 WEB数据库为中心,HTTP为传输协议,客户端通过浏览器(Browser)访问WEB服务器和与其相连的后台数据库,我们称之为B/S(Browser/Server)模式。其三级结构组成如图2-2所示:图 2-2 B/S三层结构图图中从左到右,分为三个层次:第一层是客户端即浏览器,主要完成客户和后台的交互及最终查询结果的输出功能。在客户端向指定的Web服务器提出服务器请求,Web服务器用 HTTP协议把所需文件资料传给用户,客户端接受并显示在WWW浏览器上;第二层 Web服务器是功能层,完成客户的应用功能,即 Web服务器接受客户请求,并与后台数据库连接,进行申请处理,然后将处理结果返回 Web服务器,再传至客户端;第三层数据库服务器是数据层。数据库服务器应客户请求独立地进行各种处理。与传统的 C/S 模式相比,B/S 结构把处理功能全部移植到了服务器端,用客户端 WEB服务器 后台数据库客户端第 3 页 共 23 页户的请求通过浏览器发出,无论是使用和数据库维护上都比传统模式更加经济方便。而且使维护任务层次化:管理员负责服务器硬件日常管理和维护,系统维护人员负责后台数据库数据更新维护。由以上的分析可知,三层结构也可以理解为增加WEB服务器的C/S 模式。 StrutsStruts is 是 Apache Jakarta 项 目 的 一 部 分 , 它 用 JavaServlet/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与JavaServerPages协同工作,包含JSTL和JSF。 SpringSpring 框架是一个分层架构,由 7个定义良好的模块组成。Spring 模块构建在核心容器之上,核心容器定义了创建、配置和管理 bean 的方式,如图2-3 所示:图 2-3 Spring框架的 7个模块图第 4 页 共 23 页组成 Spring 框架的每个模块(或组件)都可以单独存在,或者与其他一个或多个模块联合实现。每个模块的功能如下: 核心容器:核心容器提供 Spring 框架的基本功能。核心容器的主要组件是 BeanFactory,它是工厂模式的实现。BeanFactory 使用控制反转(IOC)模式将应用程序的配置和依赖性规范与实际的应用程序代码分开。 Spring 上下文:Spring 上下文是一个配置文件,向 Spring 框架提供上下文信息。Spring 上下文包括企业服务,例如 JNDI、EJB、电子邮件、国际化、校验和调度功能。 Spring AOP:通过配置管理特性,Spring AOP 模块直接将面向方面的编程功能集成到了 Spring 框架中。所以,可以很容易地使 Spring 框架管理的任何对象支持 AOP。SpringAOP 模块为基于 Spring 的应用程序中的对象提供了事务管理服务。通过使用 Spring AOP,不用依赖 EJB 组件,就可以将声明性事务管理集成到应用程序中。 Spring DAO:JDBC DAO 抽象层提供了有意义的异常层次结构,可用该结构来管理异常处理和不同数据库供应商抛出的错误消息。异常层次结构简化了错误处理,并且极大地降低了需要编写的异常代码数量(例如打开和关闭连接)。Spring DAO 的面向 JDBC 的异常遵从通用的 DAO 异常层次结构。 SpringORM:Spring 框架插入了若干个 ORM 框架,从而提供了 ORM 的对象关系工具,其中包括 JDO、Hibernate 和 iBatis SQL Map。所有这些都遵从 Spring 的通用事务和 DAO 异常层次结构。 Spring Web 模块:Web 上下文模块建立在应用程序上下文模块之上,为基于 Web 的应用程序提供了上下文。所以,Spring 框架支持与 JakartaStruts 的集成。Web 模块还简化了处理多部分请求以及将请求参数绑定到 域对象的工作。 Spring MVC 框架:MVC 框架是一个全功能的构建 Web 应用程序的 MVC实现。通过策略接口,MVC 框架变成为高度可配置的,MVC 容纳了大量视图技术,其中包括 JSP、Velocity、Tiles、iText 和 POI。 HibernateHibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate 可以应用在任何使用 JDBC 的场合,既可以在 Java 的客户端程序实用,也可以在 Servlet/JSP 的Web 应用中使用,最具革命意义的是,Hibernate 可以在应用 EJB 的J2EE 架构中取代 CMP,完成数据持久化的重任。第 5 页 共 23 页2.2 开发环境及相关技术介绍2.2.1 开发环境本设计主要运用 JSP语言、Hibernate、Struts等知识,在 Window Xp 的环境下,采用 SQL Server2000 数据库,用 Eclipse3.2 + MyEclipse5.0 +Tomcat5.5 + j2sdk1.5 搭建J2EE开发环境进行开发。2.2.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 设计成利用 Windows2000 对更多处理器、更大的系统内存的支持,最终达到支持 64 位硬件平台。在不断提升可用性的努力过程中,SQL Server 2000 采用 Windows 2000 四路群集,提供了大大改进的群集支持。SQL Server 7.0 已经在可管理性和易用性方面在行业内领先,SQL Server 2000 通过与 Windows 2000 活动目录紧密结合进一步改进了这些功能。而且,SQL Server 2000 还包含对现有管理工具和实用程序的重大改进,并引入更具自我调节和自我管理的引擎功能。通过与 OLAP 服务、数据转换服务、存储库和英文查询的紧密结合,SQLServer7.0 代表了行业内最全面的数据仓库和决策支持平台。SQLServer2000继续了这种创新,在整个系统内进行了重要的改进。特别重要的是,SQLServer2000 关系引擎增加了实质化的视图,改善了在特大型数据库环境中执行复杂查询的性能。同时,SQL Server 2000 引入了新的数据挖掘功能,可自动发现在大量数据之间隐藏的关系并可基于历史数据做出预测。这些数据挖掘功能将要实施,以向最终用户隐藏这种尖端技术的复杂性,并允许开发人员将第三方的第 6 页 共 23 页数据挖掘产品轻松集成进客户的应用程序中。最后,在电子商务领域,SQLServer 2000 高度集成了对XML 和通过 Web 访问数据库的支持。SQL Server 2000 按照设计可以为部署和维护强大的、易于管理、支持商务活动的Web 站点提供最好的性能,这些站点可以从事商家和商家之间或商家与客户之间的交易。在寻求一个支持您的电子商务解决方案的数据库时,需要考虑的项目包括:可用性、性能、可管理性和价格。 Eclipse介绍Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括 Java 开发工具(JavaDevelopment Tools,JDT)。虽然大多数用户很乐于将 Eclipse 当作 Java IDE 来使用,但 Eclipse的目标不仅限于此。Eclipse 还包括插件开发环境(Plug-in DevelopmentEnvironment,PDE),这个组件主要针对希望扩展 Eclipse 的软件开发人员,因为它允许他们构建与 Eclipse 环境无缝集成的工具。由于 Eclipse 中的每样东西都是插件,对于给 Eclipse 提供插件,以及给用户提供一致和统一的集成开发环境而言,所有工具开发人员都具有同等的发挥场所。这种平等和一致性并不仅限于 Java 开发工具。尽管 Eclipse 是使用Java 语言开发的,但它的用途并不限于 Java 语言;例如,支持诸如 C/C+、COBOL 和 Eiffel 等编程语言的插件已经可用,或预计会推出。Eclipse 框架还可用来 作为与软件开发无关的其他应用程序类型的基础,比如内容管理系统。基于 Eclipse 的应用程序的突出例子是 IBM 的 WebSphere StudioWorkbench,它构成了 IBMJava 开发工具系列的基础。例如,WebSphereStudioApplicationDeveloper 添加了对 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虚拟器。1 系统需求分析需求分析是一切工作的基础,他告诉我们将要做什么。只有当了解了所需要做的任务后,才能对整个系统进行设计。本课题主要实现 SMART在线考试系统的部分功能-考试过程的监控及对客观题的自动阅卷。1.1 考试监控模块需求分析考试监控模块的设计,主要是实现对学生参加考试的整个过程的设计及老师对学生考试的监视与控制,包括查看学生信息,改变学生考试状态等。学生要参加考试,必须根据学生的相关信息(如班级,学号,姓名等)以及当前的服务器时间,来查找该生有权限参加的考试信息并显示在页面上。学生通过点击相应的考试,进入到该门考试的答题界面。为了确保考试的有效性和安全性,系统必须设定一下规则:(1).只有学生才能参加考试。(2).学生在考试过程中,不能同时进行其他课程的考试。(3).对学生来说,每一门考试只允许考一次;如果已经交卷,系统将会禁止其重新进行考试。如果需要进行补考或者重考,教师可以另外设置一份考卷,让学生进行考试。为防止相邻学生之间可能会出现作弊的情况,要求在学生答题界面生成的题目要随机排序。并且答题页面要禁止实用复制和右键功能。考虑到学生答题过程中有可能会出现断线、死机、电脑故障等问题或者是要返回已经做过的题目,要实现对学生做了的题目答案进行实时保存。当学生要查看已经做过的题目时,要把题目的答案回调在页面上。监控端主要涉及到对学生考试过程的管理。学生登陆系统时,要判断其是迟到还是由于考试过程中异常情况而重登陆。如果是迟到,则该生的考试时间不推迟,如果是由于考试过程中发生异常情况而造成的重登陆,则需要将学生在重登陆系统所浪费的这个时间补偿给学生。学生登陆系统时,都要将信息提交到监控端。监考老师可以通过监控页面直观地看出学生的状态,并且可以改变其中的一个或多个学生的考试状态(如重新考试,结束考试等),改变状态后,学生考试界面要出现相应的提示信息。第 8 页 共 23 页1.2 阅卷模块需求分析传统的手工改卷,工作量既繁重又低效,出错的几率比较高。为了使学生的考试更加趋向于公平公正,本模块主要实现对客观题的自动阅卷(如判断题、多选题、单选题等),来代替传统的老师手工该卷。在学生主动提交考卷、老师强制提交或者是考试结束时间到了自动提交后,要对学生当前的考试进行系统自动阅卷,并统计出学生的各项大题分数和总分,为后面的评估做好基础。学生考试结束后,如果试卷的组成都是客观题,则学生可以马上查看自己的得分。3 系统数据库设计数据库设计也是一个很重要的环节。设计一个合理的数据库,能够让程序员在写代码的时候有很强的逻辑性,而不再为了理清数据库表间的关系浪费大量的时间和精力。在以后的系统运行中,数据库也担当着重要的角色,不合理的数据库往往是成为一个系统的瓶颈。3.1 考试监控模块数据库设计此模块主要涉及到的数据库表有如下几张:学生用户表: 表 4-1 学生用户表(SMART_STUDENT)学生用户表 SMART_STUDENT字段名称 数据类型 是否是主键 是否是外键 是否可 NULL 备注Student_id DECIMAIL(18,0) YES NO NO 自增IDStudent_no VARCHAR(50) NO NO NO 学生NOUin VARCHAR(20) NO NO NO UINstudent_name VARCHAR(50) NO NO NO 学生姓名Province_no VARCHAR(50) NO NO YES 省city_no VARCHAR(50) NO NO YES 市county_no VARCHAR(50) NO NO YES 区/县ref_school_no VARCHAR(50) NO NO YES 学校ref_grade_no VARCHAR(50) NO NO YES 年级ref_class_no VARCHAR(50) NO NO YES 班级Register_id BIGINT NO NO YES 注册时的用户IDTel VARCHAR(20) NO NO YES 联系电话e_mail VARCHAR(50) NO NO YES E_Mail地址address VARCHAR(100) NO NO YES 地址信息register_date DATETIME NO NO YES 注册时间record_number INTEGER NO NO NO 版本控制remark VARCHAR(100) NO NO YES 备注第 9 页 共 23 页班级表: 表 4-2 班级表(smart_class)班级表 smart_class字段名称 数据类型 是否是主键 是否是外键 是否可 NULL 备注class_id UNIQUEIDENTIFIER YES NO NO 全球唯一码Class_name VARCHAR(50) NO NO NO 班级名字class_no VARCHAR(50) NO NO NO 班级编号class_no VARCHAR(2500) NO NO YES 班级描述length INTEGER NO NO YES 编号长度lastclass_no VARCHAR(50) NO NO YES 上一级别编号ruleclass_name VARCHAR(50) NO NO YES 设置的名称lastname VARCHAR(50) NO NO YES 上级别名称nextname VARCHAR(50) NO NO YES 下级别名称record_number INTEGER NO NO NO 版本控制Remark VARCHAR(100) NO NO YES 备注考试监控表: 表 4-3 考试监控表(smart_exam_control)考试监控表 smart_exam_control字段名称 数据类型 是否是主键 是否是外键 是否可NULL 备注control_id UNIQUEIDENTIFIER YES NO NO 全球唯一码exam_name VARCHAR(1000) NO NO NO 考试名称student_no VARCHAR(50) NO NO NO 学生 NOstudent_name VARCHAR(20) NO NO NO 学生姓名class_no VARCHAR(50) NO NO NO 学生所在班级号Ip VARCHAR(50) NO NO YES 登陆 IPstudent_state VARCHAR(20) NO NO NO 学生状态now_time DARETIME NO NO NO 写入时间start_time DARETIME NO NO NO 考试开始时间end_time DARETIME NO NO NO 考试结束时间exam_delay DARETIME NO NO NO 考试时长landing_time DARETIME NO NO NO 登陆考试时间submit_time DARETIME NO NO NO 提交考试时间exam_tate VARCHAR(50) NO NO NO 考试状态record_number INTEGER NO NO NO 版本控制Remark VARCHAR(100) NO NO YES 备注第 10 页 共 23 页3.2 阅卷模块数据库设计此模块主要涉及到的数据库表有:考试临时表: 表 4-4 考试临时表(temp_smart_exam)考试临时表 temp_smart_exam字段名称 数据类型 是否是主键 是否是外键 是否可NULL 备注Exam_temp_id UNIQUEIDENTIFIER YES NO NO 全球唯一码exam_paper_no UNIQUEIDENTIFIER NO NO NO 试卷号exam_paper_question_no VARCHAR(50) NO NO NO 试题号exam_name VARCHAR(50) NO NO NO 考试名称student_no VARCHAR(50) NO NO NO 学生NOstudent_name VARCHAR(20) NO NO NO 学生姓名Answer VARCHAR(50) NO NO YES 试题答案record_number INTEGER NO NO NO 版本控制Remark VARCHAR(100) NO NO YES 备注考试结果表: 表 4-5 考试结果表(smart_exam_result)考试结果表 smart_exam_result字段名称 数据类型 是否是主键 是否是外键 是否可NULL 备注smart_exam_result_id UNIQUEIDENTIFIER YES NO NO 全球唯一码exam_paper_no UNIQUEIDENTIFIER NO YES NO 试卷号exam_paper_question_no UNIQUEIDENTIFIER NO YES NO 试题号exam_name VARCHAR(50) NO NO NO 考试名称student_no UNIQUEIDENTIFIER NO YES NO 学生 NOstudent_name VARCHAR(20) NO NO NO 学生姓名Answer VARCHAR(50) NO NO YES 试题答案Is_right INTEGER NO NO YES 是否正确Score FLOAT NO NO YES 试题得分record_number INTEGER NO NO NO 版本控制Remark VARCHAR(100) NO NO YES 备注第 11 页 共 23 页考试结果统计表:表 4-6 考试结果统计表(smart_exam_stat_result)考试结果统计表 smart_exam_stat_result字段名称 数据类型 是否是主键 是否是外键 是否可NULL 备注smart_exam_stat_result_id UNIQUEIDENTIFIER YES NO NO 全球唯一码exam_paper_no UNIQUEIDENTIFIER NO YES NO 试卷号exam_name VARCHAR(50) NO NO NO 考试名称student_no UNIQUEIDENTIFIER NO YES NO 学生NOstudent_name VARCHAR(20) NO NO NO 学生姓名Single_choice_score FLOAT NO No YES 单选题得分multi_choice_score FLOAT NO NO YES 多选题得分judgement_score FLOAT NO NO YES 判断题得分score_total FLOAT NO NO YES 总分record_number INTEGER NO NO NO 版本控制Remark VARCHAR(100) NO NO YES 备注4 系统功能设计及实现4.1 考试监控模块设计及实现考试监控模块的设计,是指对整个考试过程及考试过程中发生的一些事件进行监视和控制。总体流程如下:1. 学生在点击参加考试后,通过对学生所在的班级 NO的判断,查找出所有该班有权限参加的考试,再通过发卷时间与服务器当前时间的比对,在页面上显示出符合该生的考试信息。第 12 页 共 23 页图 5-1 学生考试信息图主要实现代码:通过用户登陆时写入Session的用户类型,判断是否是学生用户。如果是,则通过用户ID查找到该用户对应的班级NO,再通过班级NO查找对应的符合该班级的考试信息。/得到用户登陆是存在Session中的用户类型及用户IDAuthorization user =(Authorization)request.getSession().getAttribute(Constants.USER_KEY);/用户IDLong 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);/得到学生所在班级NOString 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:12tailDatetime - 日期尾 格式为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内的元素写入到resultListresultList.add(smartExam);/写入sessionrequest.getSession().setAttribute(resultList, resultList);2. 学生通过点击对应的考试进入考试界面(此时将学生的信息,如姓名、学号、登陆时间、登陆IP等写入监控表),进行答题。图 5-2 学生考试答题图第 14 页 共 23 页学生考试过程中要定时的获取服务器时间(比如10秒),再将该时间写入监控表,服务器端也要每隔一段时间去读取监控表内的该时间,如果该时间很久没有刷新,则说明此时考试端可能出现了异常情况(如掉线、死机等)。这样就方便管理员去管理学生考试。流程图如下:用户考试端获取服务器时间并写监控表流程图:图 5-3 用户考试端获取并写监控表流程图用户监控端读取监控表流程图:图 5-4 用户监控端读取监控表流程图3. 监控端监考老师可以选择一个或多个班级进行监控。通过选择班级后,将这些班级的所有参加当前考试的学生信息罗列出来,监考老师可以对学生进行相应的操作。具体实现:监考老师可以直接选择要监控的班级,或者也可以通过年级查询先过滤一些年级再进行操作。点击确定后跳到对应班级的所有学生的监控页面。第 15 页 共 23 页图 5-5 用户监控端班级列表图监考老师可以实时获得各个学生的考试状态。也可以对某个或多个学生进行对应的考试操作,如让他们重新考试或者是结束考试等。图 5-6 用户监控端监控页面图用户监控端改变考试状态流程图:图 5-7 用户监控端改变考试状态流程图第 16 页 共 23 页用户考试端获取考试状态
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 生物发酵工程技术在生物发酵产业产业链优化升级中的应用前景报告
- 2024年9月计算机四级网络工程师笔试试题
- 基于大数据的互联网医疗美容服务模式创新研究评估报告
- 绿色建筑认证体系在绿色住宅社区的推广与应用分析报告
- 2023年职业技能学历双提升工程实施方案
- 绿色消费理念在2025年绿色家居窗帘品牌推广中的传播与消费者引导报告
- 2023年监理工程师的工作考试答案
- 2023幼儿园食品安全工作计划
- 2023年继续教育八大员安全员考试+答案
- 2023年造价工程师安装工程真题加参考答案及解析
- 第12章一次函数 单元测试 数学八年级上册 沪科版
- 2025平面设计合同范本
- 养老服务投标文件(技术方案)
- 宁夏中卫人文介绍
- 湖南省英语高考试题与参考答案(2025年)
- 行政执法资格证法律知识考试复习题及答案
- 广西壮族自治区2025年普通高校招生考生报名登记表(样表)
- 统编版语文三年级上册第6单元大单元教学设计
- 精神分裂症合并糖尿病患者护理查房课件
- GB/T 44230-2024政务信息系统基本要求
- 宫腔镜技术诊断子宫内膜癌的临床应用
评论
0/150
提交评论