毕业设计论文基于Web的网上考试系统.doc

上传人:sccc 文档编号:4864624 上传时间:2023-05-20 格式:DOC 页数:27 大小:1.02MB
返回 下载 相关 举报
毕业设计论文基于Web的网上考试系统.doc_第1页
第1页 / 共27页
毕业设计论文基于Web的网上考试系统.doc_第2页
第2页 / 共27页
毕业设计论文基于Web的网上考试系统.doc_第3页
第3页 / 共27页
毕业设计论文基于Web的网上考试系统.doc_第4页
第4页 / 共27页
毕业设计论文基于Web的网上考试系统.doc_第5页
第5页 / 共27页
点击查看更多>>
资源描述

《毕业设计论文基于Web的网上考试系统.doc》由会员分享,可在线阅读,更多相关《毕业设计论文基于Web的网上考试系统.doc(27页珍藏版)》请在三一办公上搜索。

1、基于web的在线考试系统2008/05/02基于Web的网上考试系统内容目录27271 绪论52开发方案62.1问题分析62.2 项目目的72.3 方案选择82.4 开发框架技术153需求分析183.1 任务概述183.2 功能需求概述193.2运行环境234系统设计234.2 数据库设计274.3 系统模块部分设计325关键技术解决475.1系统架构与数据库的连接476结束语517参考文献528【ABSTRACT】On-line examination system the aim is carry out examination of have no the paper turn a ma

2、nagement, 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 ex2008/02/02aminee is particularly suitable for examinee to distribute widely and not easily concentrated of long range educati

3、on.I mainly develop the system-JAVA of the backstage managements 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 e

4、tc. function.This thesis mainly introduced to manage the analysis, design of the sub- system and all processes of the development to JAVAs 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 i

5、s 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 t

6、echnique;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

7、 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.559后记55 摘要 在线考试系统旨在解放教师传统教学中制作试卷时的困惑,对一些考生不集中的考试,比如一些认证式的网上考试就比较适合这种在线考试的方式,不仅方便了制作试卷的流程,更重要的是实现了无纸化,适应可持续发展的战

8、略思想。我主要开发系统的后台管理系统JAVA在线考试管理子系统,它包括试题管理、考生管理、在线制作试卷、控制学生考试的设置等功能。本论文主要介绍了对JAVA在线考试管理子系统的分析、设计和开发的全部过程。全文共分为开发方案、需求分析、系统设计、关键技术解决,结论五部分。开发方案中主要介绍开发在线考试系统得目的、开发方案的选择及开发框架的技术的确定;需求分析介绍了在线考试系统的总体需求及系统各模块的功能需求;系统设计介绍了系统设计的指导思想、数据库的设计、系统模块的设计.关键词 JSP; JAVA; ORACLE 9i数据库; B/S模式 目录1 绪论 现阶段,学校与社会上的各种考试大都采用传统

9、的考试方式,在此方式下,组织一次考试至少要经过五个步骤,即人工出卷,考生考试,人工阅卷,成绩评估和试卷分析.显然,随着考试类型的不断增加及考试要求的不断提高,教师的工作量将会越来越大,并且其工作将是一件十分烦琐和非常容易出错的事情,可以说传统的考试方式已经不能适应现代考试的需要.随着计算机应用的迅猛发展,网络应用不断扩大,如远程教育和虚拟大学的出现等等,且这些应用正逐步深入到千家万户.人们迫切要求利用这些技术来进行在线考试,以减轻教师的工作负担及提高工作效率,与此同时也提高了考试的质量,从而使考试更趋于公证! 这个方案在技术上来讲我们是采用B/S模式,自动给每个考生生成一份试卷,考生在线作答,

10、考试结果数据通过网络回收,系统自动进行判分,生成考试成绩和统计数据。“在线考试系统”是集合现代考试理论、方法和现代信息技术手段的智能化网上考试系统,为学生个性化学习提供“灵活、方便、科学、公平”的“个别化考试服务”,是终结性评价系统。学生可以随时、随地进行课程结业考试。2 开发方案2.1问题分析传统的学校教学中,进行一场考试,要求老师刻试卷、印试卷、安排考试、监考、收集试卷、评改试卷、讲评试卷和分析试卷,这是一个繁杂的过程,需要大量人力、物力与时间的投入,已经越来越不适应学校信息化建设与现代教学的需要。尤其在远程网络教学中,学生分布广,不易统一集中安排考试,给校方和学生带来了众多的不便。而在线

11、考试系统,正是信息化建设的产物,它是传统考场的延伸。它可以利用互联网络和局域网,随时随地的对学生进行考试,加上数据库技术的利用,大大简化了传统考试的过程,因此在线考试是电子化教学的不可缺少的辅助手段。在当今信息时代,计算机技术与网络技术越来越广地应用于各个领域,改变着人们的学习、工作、生活乃至思维方式,也引起了教育领域的重大变革。将计算机与网络技术应用于现代高等教育中,是现代高等教育发展的需要,也是改革教育模式,提高学校教学效果和教学效率、提高科研和管理水平的必要手段。2.2 项目目的在线考试系统的总体目标:1 在线考试系统可以帮助教师完成一个考试从题目设计,考试安排,考试实施,考卷批改到分数

12、统计总结的所有工作。2所有的考试数据和其它数据库需要一种主流的方式进行存储和管理,例如使用数据库技术。3对考试的系统目标:这个软件是分布式的,这意味着只要有考试客户端可以连接到考试应用服务器,任何考生在任何地方进行身份确认,都能完成考试。题目最好有一定的稳定性和随机性。稳定性可以保证每一次考试对每一个考生是公平的,随机性可以避免作弊的发生。2.3 方案选择1、 开发在线考试系统,提出以下解决方案:选择ORACLE 9i作为后台的数据库,选择JAVA、JSP、JavaScript、Html作为应用程序开发工具,运用Tomcat服务器技术,整个系统完全基于B/S (Browser/Server)模

13、式进行设计。2、 JAVA简介 Java是Sun公司推出的新的一代面向对象程序设计语言,特别适合于Internet应用程序开发。Java的产生与流行是当今Internet发展的客观要求,Java是一门各方面性能都很好的编程语言,它的基本特点是简单、面向对象、分布式、解释的、健壮的、安全的、结构中立的、可移植的、性能很优异的、多线程的、动态的,特别适合在Internet环境上开发的应用系统。3、 Web应用程序开发环境JSP技术JSP的全称是Java Server Pages,它是SUN推出的一种动态网页技术标准。它在传统的静态页面文件(*.html,*.htm)中加入JAVA程序片段和JSP标

14、记,就构成了JSP页面。JSP具有以下的优点:a) 将业务层与表示层分离:使用JSP技术,网络开发人员可充分使用HTML来设计页面显示部分(如字体颜色等),并使用JSP指令或者JAVA程序片段来生成网页上的动态内容;b) 能够跨平台:JSP支持绝大部分平台,包括现在非常流行的LINUX系统,应用非常广泛的Apache服务器也提供了支持JSP的服务;c) 组件的开发和使用很方便:如ASP的组件是由C+,VB等语言开发的,并需要注册才能使用;而JSP的组件是用Java开发的,可以直接使用;d) 一次编写,处处运行:作为JAVA开发平台的一部分,JSP具有JAVA的所有优点,包括Write once

15、 , Run everywhere.4、 Tomcat应用服务器目前支持JSP的应用服务器是较多的,Tomcat是其中较为流行的一个Web服务器,被JavaWorld杂志的编辑选为2001年度最具创新的Java产品,可见其在业界的地位。 Tomcat是一个免费的开源的Serlvet容器,在Tomcat中,应用程序的部署很简单,你只需将你的WAR放到Tomcat的webapp目录下,Tomcat会自动检测到这个文件,并将其解压。你在浏览器中访问这个应用的Jsp时,通常第一次会很慢,因为Tomcat要将Jsp转化为Servlet文件,然后编译。编译以后,访问将会很快。Tomcat也具有传统的Web

16、服务器的功能:处理Html页面。但是与Apache相比,它的处理静态Html的能力就不如Apache。我们可以将Tomcat和Apache集成到一块,让Apache处理静态Html,而Tomcat处理Jsp和Servlet。Tomcat是一个很好的工具,不仅仅因为其免费,功能强大,更因为其开放性,越来越受到人们的重视。5、 Oracle 9i 数据库服务器是解决信息管理的主要工具。一般情况下,服务器必须在多用户环境中管理大量的数据,使得多个用户能够并行访问数据。所有这些必须能够在高性能的情况下完成,数据库服务器必须防止未经授权的非法访问,保护敏感数据,同时,为故障恢复提供解决方案。为此,Ora

17、cle服务器提供了以下特性:l 客户服务器环境l 大型数据库和空间管理l 多个并行数据库用户l 连接性l 高事务处理能力l 控制安全性l 开放的、基于工业标准l 管理安全性l 数据库完整性增强l 兼容性l 分布式系统l 复制环境 6、 B/S 开发模式伴随着Internet的迅速发展,计算机技术正在由基于C/S(client/ Server)模式的应用系统转变为基于B/S模式的应用系统。过去,网络软件的开发都采用C/S(client)模式,在这种模式下,主要的业务逻辑都集中于客户端程序,因此,必然导致以下问题:a) 系统安装、调试、维护和升级困难。由于客户端的硬件配置可能存在差异,软件环能各不

18、相同,因此,在安装时,必须对每一个客户端分别进行配置,同样,在软件升级时也要对客户端分别处理。b) 在整个系统中,业务逻辑和用户界面都集中到了客户端,必然会增加安全隐患。B/S模式带来了巨大的好处:a) 开发成本及维护成本降低。由于B/S架构管理软件只安装在服务器端(Server)上,即应用程序在部署、升级、维护时,只需要在服务器端进行配置就可以了,网络管理人员只需要管理服务器就行了,用户界面主要事务逻辑在服务器(Server)端完全通过WWW浏览器实现,极少部分事务逻辑在前端(Browser)实现,所有的客户端只有浏览器,网络管理人员只需要做硬件维护。b) 良好的安全性能,防火墙技术可以保证

19、后台数据库的安全性。所有的配置工作都集中在服务器端且所有客户端请求都是通过DBMS来访问数据库,从而大大减少了数据直接暴露的风险。2.4 开发框架技术对于框架技术,我们采用Struts+Hibernate的整合,其实任何一种框架都可以完成我们的项目,但我们选择两种框架的组合是因为两种框架各有好处,我们利用它们的优点,来避免它们的缺点,充分利用Java技术在web的应用。l Struts是应用比较广泛的一种表现层框架Struts是一个为开发基于模型(Model)视图(View)控制器(Controller)(MVC)模式的应用架构的开源框架,是利用Servlet,JSP和struts标签库构建W

20、eb应用的一项非常有用的技术。由于Struts能充分满足应用开发的需求,简单易用,敏捷迅速。它使用服务层框架可以将JavaBeans从Jsp/Servlet中分离出来,而使用表现层框架则可以将Jsp中剩余的JavaBeans完全分离,这部分JavaBeans主要负责显示相关信息,一般是通过标签库(Taglib)实现,不同框架有不同自己的标签库,Struts是应用比较广泛的一种表现层框架。l Hibernate通过持久层的框架将数据库存储从服务层中分离出来它是O/R Mapping的一种实现是目前在JAVA界使用非常广泛的O/R Mapping的一种实现,可以实现关系型数据库和对象之间的映射。用

21、来开发数据库系统非常方便,可以将数据库和程序的设计融合在一起。表现层和服务层的分离是通过两种框架达到目的的,剩余的就是持久层框架了,通过持久层的框架将数据库存储从服务层中分离出来就是其目的,持久层框架有两种方向:直接自己编写JDBC等SQL语句(如Ibatis);使用O/R Mapping技术实现的Hibernate和JDO技术;当然还有EJB中的实体Bean技术。Hibernate的工作原理是通过文件把值对象和数据库表之间建立起一个映射关系,这样,我们只需要通过操作这些值对象和Hibernate提供的一 些基本类,就可以达到使用数据库的目的。例如,使用Hibernate的查询,可以直接返回包

22、含某个值对象的列表(List),而不必向传统的JDBC访问方式一样把结果集的数据逐个装载到一个值对象中,为我们的编码工作节省了大量的劳动。Hibernate提供的HQL是一种类SQL语言,是提供对象化的数据库查询方式,但HQL在功能和使用方式上都非常接近于标准的SQL3 需求分析3.1 任务概述在线考试管理子系统主要实现题库管理、教师管理、教学管理(包括班级管理和考生管理)、考试管理等功能,充分利用计算机科学与技术和web框架,改变传统的考试操作方式,实现无纸化考试与自动化相结合的考试模式。3.2 功能需求概述(1) 系统需要解决的主要问题我主要开发的是后台管理子系统中的题库管理,教师管理和管

23、理员管理,在此系统中我们主要对后台考试系统的进行管理和设置。我们将子系统分为以下功能模块:题库管理:在管理员权限下,对预定的十六门科目可以进行考题的增加和管理,管理主要包括按科目查询试题和删除试题。教师管理:分为添加教师,管理教师,管理教师主要包括按姓名查询教师信息和教师的删除和修改。考试管理:主要是人工组卷。由管理员设置考试科目及题目数量,该设置可以控制监考老师的考试科目的试题范围,只有管理员设置的科目监考教师才能组织考生考试,否则监考教师没有出题权限,这样可以避免试题泄露,保证了试卷的安全,也保证了考试的公正性和可靠性。教学管理:主要是对班级和考生的增,删,改,查。管理员管理:主要是管理员

24、的自管理。系统管理:管理员安全退出。其中由我负责的题库管理和教师管理的功能需求说明如下:3.2.1 功能需求说明在线考试系统部分功能分析1 题库管理1.1 增加考题在addexam.jsp页面添加一个考题,考题用作考生考试试题,当添加成功后,跳转回addexam.jsp,并发出消息通知用户试题添加成功。详细描述:1 需要判断所添加题目是否已填写完全(包括题目,选项,答案和科目) 2 判断当前session范围内是否存在一个包含选项内容的非空字符串 3 将用户录入的试题封装成一个Moban类,按照不同科目存入对应表中具体步骤:1 实现AdminDaoImpl.java中的addKaoti()方法

25、 2 创建AddoptAction 实现add()和addKaoti()两个方法,其中add()是用于选项的追加,addKaoti()用于考题的封装 3 创建addexam.jsp1.2 管理考题 在modifyexam.jsp页面,用户可以通过下拉菜单中的十六个科目选项中任意选择一个,进行考题的查询,选中后会在下方以表格形式显示所选考题的题号和题目名,也可以删除所选中的试题具体步骤:1 实现用于分页显示的Page.java 2 实现ModifyexamAction.java 3 实现DeleteexamAction和ShowexamAction 4 实现AdminServiceImpl.ja

26、va中的delexam()方法,按题号删除2 教师管理2.1 添加教师 在addexam.jsp页面中添加教师,这里添加的教师包括了普通任课教师和监考教师这里没有区别对待详细描述: 1 添加成功显示成功信息,失败显示失败信息 2 无论成功或是失败都跳回到Content1.jsp页面进行刷新具体步骤: 1 实现AdminDaoImpl.java中的updateTeacher()方法,添加教师 2 实现AdminServiceImpl.java中的updateTeacher()方法 3 创建addteacher.jsp2.2 管理教师 在listteacher.jsp页面中,用户可以通过教师姓名进

27、行查询,查询支持模糊查询,也可进行教师信息的修改。详细描述: 1 需要判断教师是否存在于数据库中,如不存在则返回到查询页,如存在则把教师信息返回显示具体步骤: 1 实现AdminDaoImpl.java中的selectTeacherByName(),delTeacher()和selectTeacher()方法 2 创建SelectTeacherAction和DeleteTeacherAction 3 创建listteacher.jsp 4 实现AdminServiceImpl.java中的delTeacher方法 5 创建ShowTeacherAction用于教师信息显示3 管理员管理3.1

28、管理员信息修改 在showadmin.jsp页面中,可修改管理员的信息,管理员信息包括管理员姓名和密码详细描述: 从adminForm中获得修改后信息,进行管理员信息的更新处理具体步骤: 1 实现AdminDaoImpl.java中的updateTeacher()方法 2 实现AdminSericeImpl.java中的updateTeacher()方法 3 创建MdifyadminAction实现管理员信息的更新3.2运行环境l 硬件需求: PIII/256M/10G 及以上配置,要求为考试系统分配足够的数据库磁盘空间l 推荐配置: PIV 2G/512M/40Gl 操作系统需求: Sun

29、Solaris等Linux操作系统 ( 推荐 ) ,也可以使用 Windows2000 等 win系列操作系统l 数据库软件需求: Oracle 9i/10g ( 推荐 ) ,也可以使用 SQL Server 2000 或mySql数据库l 中间件软件需求:Apache Tomcat/5.0.28系列服务器4 系统设计4.1 系统结构图4.1.1 本系统分为学生前台子系统、教师子系统、监考教师子系统和管理员子系统,整个系统的结构图如下:4.1.2 系统的用例图如下:4.2 数据库设计4.2.1 主要数据库表的介绍 根据系统需要和考试需要,设立了如下数据库表:各种题库表:我们只设置了一种类型的题

30、,即选择题,有十六个科目存储在十六个表中,表结构均一致:用于保存所添加题的题目,选项,答案和科目。学生表:用于保存学生的考号,姓名,所在班级,登录密码,上线状态(1为在线),还有分数。成绩表:用于存储学生的考试成绩。4.2.2 主要数据库表的结构主要表结构如下:物理名称:examstate(考试状态表) 字段名 字段类型 约束或索引 描述idnumberPK记录流水号statenumber记录考试状态(1提交0未提交)物理名称:state(记录在线表) 字段名 字段类型 约束或索引 描述idnumberPK记录流水号statenumber记录登录状态(1在线0离线)物理名称:student(学

31、生表)字段名 字段类型约束或索引描述idnumberPK记录流水号kaohaovarchar2考号namevarchar2学生姓名banjivarchar2班级passwordvarchar2学生密码statenumber考试状态1-在线0下线scorenumber分数物理名称:teacher(教师表)字段名 字段类型约束或索引描述idnumberPK记录流水号namevarchar2教师姓名passwordvarchar2教师密码statenumber考试状态1-在线0下线物理名称:jteacher(监考教师表)字段名 字段类型约束或索引描述idnumberPK记录流水号namevarcha

32、r2监考教师姓名passwordvarchar2监考教师密码statenumber考试状态1-在线0下线物理名称:admin(管理员表)字段名 字段类型约束或索引描述idnumberPK记录流水号namevarchar2管理员姓名passwordvarchar2管理员密码statenumber考试状态1-在线0下线物理名称:chengji(成绩表)字段名 字段类型约束或索引描述idnumberPK记录流水号kaohaovarchar2考号namevarchar2学生姓名banjivarchar2班级kechengvarchar2课程maxscorenumber总分scorenumber分数物理

33、名称:banji(班级表)字段名 字段类型约束或索引描述idnumberPK记录流水号namevarchar2班级名称numnumber班级人数classvarchar2所在的教室名称timevarchar2开课的时间题库表物理名称:nuix字段名 字段类型约束或索引描述idnumberPK记录流水号questionvarchar2题目optvarchar2选项answervarchar2答案其它十五个题库表结构和上例一致,分别为java表,oracle表,xml表,jdbc表,hibernate表,servlet表,html表,jsp表,struts表,ajaxjsf表,ooaduml表,e

34、jb表,spring表,webservice表,plsql表4.3 系统模块部分设计4.3.1 用户登录:首先选择登录人身份:考生:对于管理员已添加的考生,可根据自己的考生号和密码登录,登录界面如下:教师:对于管理员已添加的教师,可根据该教师的教师号和密码登录,登录界面如下:监考教师登陆界面: 监考教师,可根据该教师的教师号和密码登录,登录界面如下:管理员:管理员根据管理员号和密码登录,登录界面如下:根据不同身份,登录不同界面,添好登录信息后点击“登陆”按钮;登录信息都正确,登陆成功,进入系统各个用户界面;主要代码:LoginAction.javapublic ActionForward ex

35、ecute(ActionMapping mapping, ActionForm form,HttpServletRequest request, HttpServletResponse response) LoginForm loginForm = (LoginForm) form;Student student = null;AdminService adminiServie =(AdminService) BeanFactory.getBean(BeanFactory.FadminService);StudentDao studentDao = (StudentDao) BeanFacto

36、ry.getBean(BeanFactory.FstudentDao);StudentService studentService = (StudentService) BeanFactory.getBean(BeanFactory.FstudentService);Integer admin =Integer.parseInt(request.getParameter(ss);if(null!=admin&admin.equals(3)return adminLogin(mapping,form,request);if(null!=admin&admin.equals(1)return te

37、acherLogin(mapping,form,request);if(null!=admin&admin.equals(2)return jteacherLogin(mapping,form,request);try student = studentService.Login(loginForm.getLoginName(); if(null = student) request.setAttribute(message, 该考生不存在!);throw new ServiceException(); if (!loginForm.getLoginPassword().equals(stud

38、ent.getPassword() request.setAttribute(message, 密码不正确!); throw new ServiceException(); request.getSession().setAttribute(student, student); Examstate state = adminiServie.getExamState(); if(state.getState()=0)return mapping.findForward(chengji); student.setState(1); student.setScore(0); studentServi

39、ce.update(student); catch (ServiceException e) e.printStackTrace();return mapping.findForward(false);return mapping.findForward(true);private ActionForward jteacherLogin(ActionMapping mapping, ActionForm form, HttpServletRequest request) LoginForm loginForm = (LoginForm) form;AdminService adminServi

40、ce = (AdminService) BeanFactory.getBean(BeanFactory.FadminService); AdminDao adminDao = (AdminDao) BeanFactory.getBean(BeanFactory.FadminDao);try Teacher teacher = adminService.Loginteacher(loginForm.getLoginName(); if(null = teacher) request.setAttribute(message, 这个监考教师不存在!);throw new ServiceExcept

41、ion(); if (!loginForm.getLoginPassword().equals(teacher.getPassword() request.setAttribute(message, 密码不正确!); throw new ServiceException();List list = adminDao.selectBanji();request.getSession().setAttribute(banjiall, list); request.getSession().setAttribute(teacher, teacher); return mapping.findForw

42、ard(jteacher); catch (Exception e) e.printStackTrace(); return mapping.findForward(false);private ActionForward teacherLogin(ActionMapping mapping, ActionForm form, HttpServletRequest request) LoginForm loginForm = (LoginForm) form;AdminService adminService = (AdminService) BeanFactory.getBean(BeanF

43、actory.FadminService);try Teacher teacher = adminService.Loginteacher(loginForm.getLoginName(); if(null = teacher) request.setAttribute(message, 这个教师不存在!);throw new ServiceException(); if (!loginForm.getLoginPassword().equals(teacher.getPassword() request.setAttribute(message, 密码不正确!); throw new ServiceException(); request.getSession().setAttribute(teacher, teacher); return mapping.findForward(teacher); catch (ServiceException e) e.printStackTrace(); return mapping.findForward(false);public ActionForward adminLogin(ActionMapping mapping, ActionForm form,HttpS

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 农业报告


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号