安徽工业大学
毕业设计(论文)说明书
基于 JAVAEE 的在线考试系统
学生 孙超
指导老师: 肖维民
【内容提要】 在线考试系统旨在实现考试的无纸化管理,对一些科目的考试可
以通过互联网络或局域网进行,方便校方考务的管理,也方便了考生,尤其适合考生
分布广,不易集中的远程教育。我主要开发系统的后台管理系统—JAVA 在线考试管
理子系统,它包括试题管理、考生管理、试卷管理、试卷自动审批等功能。本论文主
要介绍了对 JAVAEE 在线考试系统的分析、设计和开发的全部过程。运用 ER 图,程序
流程图等对在线系统的设计过程进行详细的说明。全文共分为开发方案、需求分析、
系统设计、关键技术解决,结论五部分。开发方案中主要介绍开发在线考试系统得目
的、开发方案的选择及开发框架的技术的确定;需求分析介绍了在线考试系统的总体
需求及系统各模块的功能需求;系统设计介绍了系统设计的指导思想、数据库的设计、
系统模块的设计;关键技术介绍了在具体实现时需解决的一些技术,如开发框架的整
合技术、开发
框架与数据库的连接及数据的备份与还原。
【关键词】:JSP, Servlet, Struts, JAVA,MySQL 数据库,B/S 模式
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
共 37 页 第 1 页
安徽工业大学
毕业设计(论文)说明书
On-line examination system base on JAVA
Student : CHAO SUN supervisor: WEI MING XIAO
【ABSTRACT】On-line examination system the aim is carry out examination of
have no the paper turn a management, can carry on through Internet net or bureau
area net to some examinations of categories, convenient school square test
the management of duty, also convenient the examinee is particularly suitable
for examinee to distribute widely and not easily concentrated of long range
education.I mainly develop the system-JAVAEE of the backstage management's
on-line examination management sub- system of system and it includes to try
the management, on-line creation of a management, examinee to try book,
control the constitution that the student examine and try an examination and
approval etc. function.This thesis mainly introduced to manage the analysis,
design of the sub- system and all processes of the development to JAVAEE's
on-line examination.Make use of ER diagram, procedure flow chart etc. to
on-line manage the design process of sub- system to carry on expatiation.The
full text is totally divided into the design, key technique of the analysis,
system of the development project, need to solve, conclusion five part.Develop
the main introduction in the project develops on-line examination system
purpose, development project of choice and development frame of the assurance
of technique;The need analysis introduced the total need of the on-line
examination system and the function request of each mold of system piece;The
system design introduced the design, system mold of the instruction thought,
database of system design the design of the piece;The key technique introduced
at concrete carry out need some techniques for solve, such as development frame
of integration technique, development frame with The database link and the
backup and revivification of data.
Keyword:
Servlet ,JSP, JAVA,MySql, Model of B/ S
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
共 37 页 第 2 页
安徽工业大学
毕业设计(论文)说明书
目录
前言 .................................................. 错误!未定义书签。
1、开发方案 ............................................................ 4
1.1 问题分析 ........................................................4
1.2 项目的目的 ......................................................5
1.3 方案的选择 ......................................................5
1.4 开发框架技术 ....................................................7
2、开发软件 ............................................................ 8
2.1 任务的概述 ......................................................8
2.2 运行环境 ........................................................9
3、系统设计 ............................................................ 9
3.1 指导思想 ........................................................9
○1 、B/S 结构开发思想..............................................................................................................9
○2 、系统工程的流程思想.......................................................................................................10
○3 、面向对象机制的设计思想...............................................................................................10
○4 、代码分层思想...................................................................................................................10
3.2 系统结构图 .....................................................11
○1 、本系统分为学生考试子系统...........................................................................................11
○2 、系统的用例图如下:.......................................................................................................12
○3 、系统部分模块类图:.......................................................................................................13
3.3 数据库设计 .....................................................16
○1 、主要数据库表的介绍.......................................................................................................16
○2 、数据库 E-R 图...................................................................................................................16
○3 、数据库表的创建语句及表的属性;................................................................................ 17
3.4 系统模块部分设计 ..............................................18
3.4.1 用户登录..................................................................................................................... 18
3.4.2 考试主界面:................................................................................................................ 20
3.4.3 管理里员后台登录....................................................................................................... 24
4、关键技术的问题 ..................................................... 29
4.1 系统的构架和数据库的 ...........................................29
4.2 框架的整合技术 ................................................30
4.3 映射文件 struts-config.xml .....................................32
4.4 访问数据库的工具 ...............................................34
5、 结束语 ............................................................ 36
参考文献 .............................................................. 36
致谢 .................................................. 错误!未定义书签。
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
共 37 页 第 3 页
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
安徽工业大学
毕业设计(论文)说明书
前言
现今,不管是国内还是国外的各大厂家,都在不断的推出一系列的考试、认证。如微
软的 MCSE、Cisco 的 CCNA 等。我们国家的自考或是成考,以及各省市的各种考试,
现在都在朝着信息化的道路前进在走。我们相信在今后这一系列的考试将会走向网络
化考试的。这样才是符合信息发展的。所以我们考虑这是一个机会。我们要给不同的
考 试 一 个 好 的 解 决 方 案 。 这 个 方 案 在 技 术 上 来 讲 我 们 是 采 用 B/S 模 式 。 在
Windows/Linux 平台上,使用 IE 浏览器,完成抽题、考试、交卷等考试任务。
各考点模块通过网络获取题库,考点模块按照题库中的抽题策略,自动给每个考生生
成一份试卷,考生在线作答,考试结果数据通过网络回收,系统自动进行判分,生成
考试成绩和统计数据。“在线考试系统”是集合现代考试理论、方法和现代信息技术
手段的智能化网上考试系统,为学生个性化学习提供“灵活、方便、科学、公平”的
“个别化考试服务”,是终结性评价系统。学生可以随时、随地进行课程结业考试。
现阶段,学校与社会上的各种考试大都采用传统的考试方式,在此方式下,组织一次考
试至少要经过五个步骤,即人工出卷,考生考试,人工阅卷,成绩评估和试卷分析。显然,
随着考试类型的不断增加及考试要求的不断提高,教师的工作量将会越来越大,并且
其工作将是一件十分烦琐和非常容易出错的事情,可以说传统的考试方式已经不能适
应现代考试的需要。随着计算机应用的迅猛发展,网络应用不断扩大,如远程教育和虚
拟大学的出现等等,且这些应用正逐步深入到千家万户。人们迫切要求利用这些技术
来进行在线考试,以减轻教师的工作负担及提高工作效率,与此同时也提高了考试的
质量,从而使考试更趋于公证、客观、更加激发学生的学习兴趣。例如目前许多国际
著名的计算机公司所举办的各种认证考试绝大部分采用这种方式。为了适应新形势的
发展,我们推出了这一系统,使其尽快在各类考试中发挥高效,便捷的作用,把老师从
繁重的工作中解脱出来。
1、开发方案
1.1 问题分析
传统的学校教学中,进行一场考试,要求老师刻试卷、印试卷、安排考试、监考、收
集试卷、评改试卷、讲评试卷和分析试卷,这是一个繁杂的过程,需要大量人力、物
力与时间的投入,已经越来越不适应学校信息化建设与现代教学的需要。尤其在远程
网络教学中,学生分布广,不易统一集中安排考试,给校方和学生带来了众多的不便。
而在线考试系统,正是信息化建设的产物,它是传统考场的延伸。它可以利用互联网
络和局域网,随时随地的对学生进行考试,加上数据库技术的利用,大大简化了传统
考试的过程,因此在线考试是电子化教学的不可缺少的辅助手段。在当今信息时代,
计算机技术与网络技术越来越广地应用于各个领域,改变着人们的学习、工作、生活
乃至思维方式,也引起了教育领域的重大变革。将计算机与网络技术应用于现代高等
共 37 页 第 4 页
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
安徽工业大学
毕业设计(论文)说明书
教育中,是现代高等教育发展的需要,也是改革教育模式,提高学校教学效果和教学效
率、提高科研和管理水平的必要手段。
1.2 项目的目的
在线考试系统的总体目标:
在线考试系统可以帮助教师完成一个考试从题目设计,考试安排,考试实施,考卷批
改到分数统计总结的所有工作。
所有的考试数据和其它数据库需要一种主流的方式进行存储和管理,例如使用数据库
技术。
考试数据的存放和处理必须对考试保密,需要一定的安全性保障。
对考试的系统目标:
这个软件是分布式的,这意味着只要有考试客户端可以连接到考试应用服务器,任何
考生在任何地方进行身份确认,都能完成考试。
题目最好有一定的稳定性和随机性。稳定性可以保证每一次考试对每一个考生是公平
的,随机性可以避免作弊的发生。
考试的部分结果在考生考完之后就可以知道,同时提供一个机会让考生知道自己哪里
做错了,并给出反馈信息说明理由。
对教师的系统目标:
提供一个功能全面的考核管理客户端,可以进行考试设计和安排。
通过管理客户端,管理员可以进行考试的身份管理。
考生的考试结果可以被保存下来,供进行分析统计和察看。
1.3 方案的选择
开发在线考试系统,提出以下解决方案:
选择 MySQL 作为后台的数据库,选择 Java、Jsp、JavaScript、Html,Servlet,
Struts,作为应用程序开发工具,运用 Tomcat 服务器技术,整个系统完全基于 B/S
(Browser/Server),采用最流行的 MVC 模式开发;
Java 简介
Java 是 Sun 公司推出的新的一代面向对象程序设计语言,特别适合于 Internet 应
用程序开发。Java 的产生与流行是当今 Internet 发展的客观要求,Java 是一门各方
面性能都很好的编程语言,它的基本特点是简单、面向对象、分布式、解释的、健壮
的、安全的、结构中立的、可移植的、性能很优异的、多线程的、动态的,特别适合
在 Internet 环境上开发的应用系统。
Web 应用程序开发环境—JSP 技术
共 37 页 第 5 页
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
安徽工业大学
毕业设计(论文)说明书
JSP 的全称是 Java Server Pages,它是 SUN 推出的一种动态网页技术标准。它在
传统的静态页面文件(*.html,*.htm)中加入 JAVA 程序片段和 JSP 标记,就构成了
JSP 页面。JSP 具有以下的优点:
将业务层与表示层分离:使用 JSP 技术,网络开发人员可充分使用 HTML 来设计页面
显示部分(如字体颜色等),并使用 JSP 指令或者 JAVA 程序片段来生成网页上的动态
内容;
能够跨平台:JSP 支持绝大部分平台,包括现在非常流行的 LINUX 系统,应用非常广
泛的 Apache 服务器也提供了支持 JSP 的服务;
组件的开发和使用很方便:如 ASP 的组件是由 C++,VB 等语言开发的,并需要注册才
能使用;而 JSP 的组件是用 Java 开发的,可以直接使用;
一次编写,处处运行:作为 JAVA 开发平台的一部分,JSP 具有 JAVA 的所有优点,包
括 Write once , Run everywhere.
Tomcat 应用服务器
目前支持 JSP 的应用服务器是较多的,Tomcat 是其中较为流行的一个 Web 服务器,
被 JavaWorld 杂志的编辑选为 2001 年度最具创新的 Java 产品,可见其在业界的地位。
Tomcat 是一个免费的开源的 Servlet 容器,在 Tomcat 中,应用程序的部署很简单,
你只需将你的 WAR 放到 Tomcat 的 Webapp 目录下,Tomcat 会自动检测到这个文件,
并将其解压。你在浏览器中访问这个应用的 Jsp 时,通常第一次会很慢,因为 Tomcat
要将 Jsp 转化为 Servlet 文件,然后编译。编译以后,访问将会很快。
Tomcat 也具有传统的 Web 服务器的功能:处理 Html 页面。但是与 Apache 相比,
它的处理静态 Html 的能力就不如 Apache。我们可以将 Tomcat 和 Apache 集成到一块,
让 Apache 处理静态 Html,而 Tomcat 处理 Jsp 和 Servlet。Tomcat 是一个很好的工
具,不仅仅因为其免费,功能强大,更因为其开放性,越来越受到人们的重视。
MySQL 数据库
MySQL 是由 MySQL AB 公司开发的,并支持全世界最流行的开源 SQL 数据库的管理系
统,目前版本很多,MySQL5.0 对存储过程,触发器和试图有了很好的支持,成为开源数
据库的首选.
B/S 开发模式 v
伴随着 Internet 的迅速发展,计算机技术正在由基于 C/S(client/ Server)模
共 37 页 第 6 页
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
安徽工业大学
毕业设计(论文)说明书
式的应用系统转变为基于 B/S 模式的应用系统。
过去,网络软件的开发都采用 C/S(client)模式,在这种模式下,主要的业务逻辑
都集中于客户端程序,因此,必然导致以下问题:
系统安装、调试、维护和升级困难。由于客户端的硬件配置可能存在差异,软件环能
各不相同,因此,在安装时,必须对每一个客户端分别进行配置,同样,在软件升级
时也要对客户端分别处理。
在整个系统中,业务逻辑和用户界面都集中到了客户端,必然会增加安全隐患。
B/S 模式带来了巨大的好处:
开发成本及维护成本降低。由于 B/S 架构管理软件只安装在服务器端(Server)上,
即应用程序在部署、升级、维护时,只需要在服务器端进行配置就可以了,网络管理
人员只需要管理服务器就行了,用户界面主要事务逻辑在服务器(Server)端完全通
过 WWW 浏览器实现,极少部分事务逻辑在前端(Browser)实现,所有的客户端只有
浏览器,网络管理人员只需要做硬件维护。
良好的安全性能,防火墙技术可以保证后台数据库的安全性。所有的配置工作都集中
在服务器端且所有客户端请求都是通过 DBMS 来访问数据库,从而大大减少了数据直
接暴露的风险。
1.4 开发框架技术
对于框架技术,我们采用 Struts+ JavaBean+Hibernate 的整合,其实任何一种框
架都可以完成我们的项目,但我们选择三种框架的组合是因为三种框架各有好处,我
们利用它们的优点,来避免它们的缺点,充分利用 Java 技术在 web 的应用。
Struts 是应用比较广泛的一种表现层框架
Struts 是一个为开发基于模型(Model)-视图(View)-控制器(Controller)(MVC)
模式的应用架构的开源框架,是利用 Servlet,JSP 和 custom tag library 构建 Web
应用的一项非常有用的技术。由于 Struts 能充分满足应用开发的需求,简单易用,
敏捷迅速。它使用服务层框架可以将 JavaBeans 从 Jsp/Servlet 中分离出来,而使用
表现层框架则可以将 Jsp 中剩余的 JavaBeans 完全分离,这部分 JavaBeans 主要负责
显示相关信息,一般是通过标签库(Taglib)实现,不同框架有不同自己的标签库,
Struts 是应用比较广泛的一种表现层框架。
JavaBean 业务层的业务;
用户可以使用 JavaBean 将功能、处理、值、数据库访问和其他任何可以用 java
代码创造的对象进行打包,并且其他的开发者可以通过内部的 JSP 页面、Servlet、
其他 JavaBean、applet 程序或者应用来使用这些对象。用户可以认为 JavaBean 提供
了一种随时随地的复制和粘贴的功能,而不用关心任何改变。最初,JavaBean 的目
的是为了将可以重复使用的软件代码打包标准。特别是用与帮助厂家开发在综合开发
共 37 页 第 7 页
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
装
┊
┊
┊
┊
┊
订
┊
┊
┊
┊
┊
线
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
┊
安徽工业大学
毕业设计(论文)说明书
环境(IDE)下使用的 java 软件部件。这些包括如 Grid 控件,用户可以将该部件拖
放到开发环境中。从此,JavaBean 就可以扩展为一个 java web 应用的标准部件,并
且 JavaBean 部件框架已经扩展为企业版的 Bean(EJB)。
Hibernate 通过持久层的框架将数据库存储从服务层中分离出来
它是 O/R Mapping 的一种实现是目前在 JAVA 界使用非常广泛的 O/R Mapping 的一
种实现,可以实现关系型数据库和对象之间的映射。用来开发数据库系统非常方便,
可以将数据库和程序的设计融合在一起。表现层和服务层的分离是通过两种框架达到
目的的,剩余的就是持久层框架了,通过持久层的框架将数据库存储从服务层中分离
出来就是其目的,持久层框架有两种方向:直接自己编写 JDBC 等 SQL 语句(如
Ibatis);使用 O/R Mapping 技术实现的 Hibernate 和 JDO 技术;当然还有 EJB 中的
实体 Bean 技术。Hibernate 的工作原理是通过文件把值对象和数据库表之间建立起
一个映射关系,这样,我们只需要通过操作这些值对象和 Hibernate 提供的一 些基
本类,就可以达到使用数据库的目的。例如,使用 Hibernate 的查询,可以直接返回
包含某个值对象的列表(List),而不必向传统的 JDBC 访问方式一样把结果集的数据
逐个装载到一个值对象中,为我们的编码工作节省了大量的劳动。Hibernate 提供的
HQL 是一种类 SQL 语言,是提供对象化的数据库查询方式,但 HQL 在功能和使用方式
上都非常接近于标准的 SQL
2.1 任务的概述
2、开发软件
在线考试管理子系统主要实现题库管理、在线制作试卷、在线控制考试、自动评分
(客观题部分)、自动交卷、考生管理、成绩查询、试卷管理等功能,充分利用计算
机科学与技术,改变传统的考试操作方式,实现无纸化考试的模式。
系统需要解决的主要问题
此系统我们不区分个人具体做那些模块,都需要把整个的系统的每个模块做一边以下
是我们分析
在线考试管理子系统
题
库
管
理
试
卷
管
理
考
试
管
理
评
卷
管
理
成
绩
管
理
用
户
管
理
题库管理:用于对单个试题的增、删、改、查等基本维护
共 37 页 第 8 页