人人文库网 > 毕业设计 > JSJ05-005@jsp SMART系统-考试监控及阅卷模块的设计与开发(源代码+论文)
H2003032122-黄孝国-SMART系统-考试监控及阅卷模块的设计与开发.doc
JSJ05-005@jsp SMART系统-考试监控及阅卷模块的设计与开发(源代码+论文)
收藏
资源目录
压缩包内文档预览:(预览前20页/共27页)
编号:508159
类型:共享资源
大小:1.69MB
格式:ZIP
上传时间:2015-11-10
上传人:QQ28****1120
认证信息
个人认证
孙**(实名认证)
辽宁
IP属地:辽宁
12
积分
- 关 键 词:
-
毕业设计计算机
- 资源描述:
-
JSJ05-005@jsp SMART系统-考试监控及阅卷模块的设计与开发(源代码+论文),毕业设计计算机
- 内容简介:
-
分类号: TP311.1 U D C: D10621-408-(2007)5996-0 密 级:公 开 编 号: 2003032122 成 都 信 息 工 程 学 院 学 位 论 文 SMART 系统 - 考试监控及阅卷模块的设计与开发 论文作者姓名: 黄孝国 申请学位专业: 网络工程 申请学位类别: 工学 学士 指导教师姓名(职称): 李谊瑞 ( 研究员 ) 论文提交日期: 2007 年 6 月 5 日 nts SMART 系统 考试 监控 及 阅卷模块 的设计与开发 摘 要 Smart 在线考试评估系统 (简称“ SMART 系统 ” ), 是 基于 Browser/Server(简称 B/S)结构的数据库访问模式, 采用 Struts + Spring + Hibernate 作为平台搭建的框架开发的一套 新型智能的 远程教育软件。 主要用于各中小学的学生考试和教学评估。 本论文设计作为 Smart 项目的一个组成部分,主要实现了 考试过程监控和 客观题的自动阅卷 功能 。论文首先介绍了设计中所涉及到的项目背景、开发技术,并构建了 系统的 总体框架;其次根据 中小学的实际情况和 远程 教育软件项目的需求,详细地进行了数据库设计和系统功能模块设计 ,制定了各功能模块的流程图;然后采用 JAVA 编程 语言 对本论文的设计任务进行编码,并最终实现了对考试过程的监控和对客观题的自动阅卷等功能。通过 本模块的应用,可以满足 SMART 系统的 在线考试部分 需求,对 SMART 系统的应用和发展 起到一定的促进作用 。 关键词 : Hibernate; 在线考 试 ; 考试监控;阅卷 nts 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 inspectionnts 目 录 论文总页数: 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 nts 第 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 框架是考虑项目组的技术 水平可能不足以完全驾驭这nts 第 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 服务器 后台数据库 客户端 nts 第 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所示 : 图 2-3 Spring框架的 7个模块 图 nts 第 4 页 共 23 页 组成 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,完成数据持久化的重任。 nts 第 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 设计成利用 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 引入了新的数据挖掘功能,可自动发现在大量数据之间隐藏的关系并可基于历史数据 做出 预测。这些数据挖掘功能将要实施,以向最终用户隐藏这种尖端技术的复杂性,并允许开发人员将第三方的nts 第 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 和 Jspnts 第 7 页 共 23 页 规范总能在 Tomcat 中得到体现。 j2sdk介绍 J2SDK=JDK+JRE, J2SDK(Java 2 Software Development Kit) JAVA2 软件开发工具包,包括了 Java编译器和 Java 虚拟器 。 3 系统 需求分析 需求分析是一切工作的基础,他告诉我们将要做什么。只有当 了解了所需要做的任务后,才能对 整个系统进行设计。 本课题主要实现 SMART 在线考试系统的部分功能 -考试 过程的 监控及对客观题的自动阅卷。 3.1 考试监控模块 需求分析 考试监控模块的设计,主要是 实现 对 学生参加考试的整个过程的设计及老师对学生考试的 监视与控制,包括查看学生信息,改变学生考试状态等 。 学生 要参加考试,必须 根据学生的相关信息 (如班级 ,学号 ,姓名 等 )以及当前的服务器 时间 ,来查找 该生 有权限参加 的考试信息 并显示 在页面上 。 学生通过点击相应的考试 , 进入 到 该门考试的答题界面。 为了确保考试的有效性和安全性,系统必须设定一下规则: (1).只有学生才 能参加考试。 (2).学生 在考试过程中,不能同时进行其他课程的考试。 (3).对 学生 来说,每一门考试只允许考一次;如果已经交卷,系统将会禁止其重新进行考试。如果需要进行补考或者重考,教师可以另外设置一份考卷,让 学生 进行考试。 为防止相邻学生之间可能会出现作弊的情况,要求在学生答题界面生成的题目要随机排序 。 并且答题页面要禁止实用复制和右键功能。 考虑到学生答题过程中有可能会出现断线、死机、电脑故障等问题或者是要返回已经做过的题目,要实现对学生做了的题目答案进行实时保存。当学生要查看已经做过的题目时,要把题目的答 案回调在页面上 。 监控端主要涉及到对学生考试过程的管理。学生登陆系统时,要判断其是迟到还是由于考试过程中异常情况而重登陆。如果是迟到,则该生的考试时间不推迟,如果是由于考试过程中发生异常情况而造成的重登陆,则需要将学生在重登陆系统所浪费的这个时间补偿给学生。 学生登陆系统时,都要将信息提交到监控端。 监考老师可以通过 监控页面直观地看出 学生 的状态 ,并且可以 改变 其中的一个或多个 学生的考试状态 (如重新考试,结束考试等 ),改变状态后,学生考试界面 要 出现相应的提示信息。 nts 第 8 页 共 23 页 3.2 阅卷 模块 需求分析 传统的手工改卷,工作量既繁重又 低效,出错的 几率比较高。为了使学生的考试更加趋向于公平公正,本模块主要实现 对客观题的自动阅卷( 如判 断题、多选题、单选题 等 ),来代替传统的老师手工该卷 。在学生主动提交考卷、老师强制提交或者是考试结束 时间到了自动提交后, 要对 学生当前的 考试 进行 系统自动 阅卷 ,并统计出 学生 的各项大题分数 和总分 ,为后面的评估做好基础。 学生考试结束后,如果试卷的组成都是客观题,则学生可以马上查看自己的得分。 4 系统 数据库设计 数据库设计也是一个很重要的环节。设计一个合理的数据库,能够让程序员在写代码的时候有很强的逻辑性,而不再为了理清数 据库表间的关系浪费大量的时间和精力。在以后的系统运行中,数据库也担当着重要的角色,不合理的数据库往往是成为一个系统的瓶颈。 4.1 考试监控 模块 数据库设计 此模块主要涉及到的数据库表有 如下几张 : 学生用户表: 表 4-1 学生 用户 表 (SMART_STUDENT) 学生用户表 SMART_STUDENT 字段名称 数据类型 是否是主键 是否是外键 是否可 NULL 备注 Student_id DECIMAIL(18,0) YES NO NO 自增 ID Student_no VARCHAR(50) NO NO NO 学生 NO Uin VARCHAR(20) NO NO NO UIN student_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 注册时的用户 ID Tel 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 备注 nts 第 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 学生 NO student_name VARCHAR(20) NO NO NO 学生姓名 class_no VARCHAR(50) NO NO NO 学生所在班级号 Ip VARCHAR(50) NO NO YES 登陆 IP student_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 备注 nts 第 10 页 共 23 页 4.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 学生 NO student_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 学生 NO student_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 备注 nts 第 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 学生 NO student_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 备注 5 系统功能设计 及实现 5.1 考试监控模块设计及实现 考试监控模块的设计,是指对整个考试过程及考试过程中发生的一些事件进行 监视和控制。总体流程 如 下: 1. 学生在点击参加考试后,通过对 学生所在的班级 NO的判断,查找出所有该班有权限参加的考试,再通过发卷时间与服务器当前时间的比对,在页面上显示出符合该生的考试信息。 nts 第 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, nts 第 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().toSt
- 温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

人人文库网所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
2:不支持迅雷下载,请使用浏览器下载
3:不支持QQ浏览器下载,请用其他浏览器
4:下载后的文档和图纸-无水印
5:文档经过压缩,下载后原文更清晰
|