




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、在线考试题 目: java web应用开发 在线模拟考试系统的设计与实现 学 院: 软件工程与服务外包学院 专 业: 软件技术 学生姓名: xxx 班级/学号 软工xxxxxxxxx 指导老师/督导老师: xxx 摘要摘 要随着网络技术的发展,远程教育和网上考试成为网络应用的一个重要方面。近几年,在线考试特别是基于web 的在线考试系统受到越来越多的人青睐。本次项目实训的题目是在线模拟考试系统的设计与实现,系统采用浏览器/服务器模式开发,包括登录注册、在线考试、试卷设置、试题管理、分数的统计以及成绩查询等功能。系统运行在windows 操作系统上,以tomcat作为web服务器,使用ssh+j
2、sp技术和mysql 数据库实现。关键词:在线考试;浏览器/服务器;jsp;mysql;jdbc;目录目录摘 要i第一章 项目概述11.1 开发背景11.2 开发意义11.3开发工具2第二章 系统分析62.1 现状分析62.2 可行性分析62.3 设计目标72.4 功能要求82.5 系统开发环境配置9第三章 系统设计103.1数据库设计103.2系统结构设计133.3用户界面设计14第四章 系统实现174.1 数据库连接的实现方法174.2 登陆注册模块184.3考生模块214.4 教师模块264.5 管理员模块34第五章 系统测试365.1什么是软件测试365.2软件测试的目标与方法365.
3、3测试内容365.4系统的不足和展望37结束语38参考文献3938java web应用开发在线模拟考试系统的设计与实现第一章 项目概述1.1 开发背景随着我国计算机技术和通讯技术的发展,互联网的普及程度已经很广泛了,但是,现在的教育教学检验方式,还是停留在过去的纸质考试层面在,而传统的教育教学检验方式中,要进行一次考试,至少需要经过教师出题、学生考试、教师阅卷等几步,这是一个繁杂的过程,需要大量人力、物力与时间的投入,同时也让教师的工作量越来越大;现在远程教育类学校的增多,虽然利用了网络拉近了教师与学生的距离,但学生的分布过广,导致了不易统一集中安排考试,考生成本的增加等诸多难题的出现,给校方
4、和学生带来了很多的不便,因此,传统的考试方式已经不能适应现在新兴的教育教学方式的考试需要了。可以解决这些诸多难题的一种方式,就是利用internet无国界的特点,在互联网上在线考试。在线考试系统可以减轻教师的工作负担、提高工作效率,也减少了因考试而消耗不必要的人力和物力。在线考试的题目由计算机从题库中随机抽取,提高了考试的质量,考试的评判由计算机自动完成,这样使考试更趋于公证、客观。随着社会的发展和我国互联网的普及,我们的生活中的已经有很多方面都运用到了网络,比如网上购物,网上交友等,甚至现在很多人看新闻都是通过网络阅读的,在阅读新闻这个事件上,已经不仅仅局限于纸质化的报纸上了;而要把考试趋于
5、无纸化的模式,需要在线模拟考试系统来完成,这个也是现在高等教育发展的一个需求。在国内,试题库系统理论与技术的研究在最近几年取得了很大的进步。我国许多企业和高校都投入量大量的人力物力到各门课程的试题库中,并取得了一定的成就。现在的生活中已经有越来越多的等级考试运用了在线考试系统,比如会计的电算化考试、计算机等级考试、银行资格证考试等,这些已经充分说明,在线考试系统是今后我们的考试生涯中的一个发展趋势。1.2 开发意义考试是教育中一个非常重要的环节,但在以前的很长时间里,全球所有的国家都是以笔试的方式来检查焦距教学成果的,随着网络的发展,互联网已经普及的非常广泛,随着这些周围环境的改变,人们开始去
6、寻找新的方式来去达到更客观,更方便快捷的去达到考试的目的。近些年来,在国外,已经投入使用的考试系统有著名的toefl,gre网上考试系统,还有微软、思科等大公司的国际认证考试等,这些考试系统在全球范围内有众多的使用者。网络化考试系统对节约考试成本,实现远距离的同步考试,提高考试效率,确保考试结果的公平、公正、科学、及时等具有重要的意义,不仅可以动态地管理考试信息,而且还提高了教学的灵活性,相信随着技术的不断发展和网络覆盖面的不断扩大,在不断完善该考试系统的同时也会在更大的范围上应用。1.3开发工具本系统是基于tomcat为服务器,ssh+jsp+mysql数据库技术实现的一个简单的在线考试系统
7、. 1.3.1动态网页开发技术jsp(java server page)jsp(java server pages)是由sun microsystems公司倡导、许多公司参与一起建立的一种动态网页技术标准。jsp技术有点类似asp技术,它是在传统的网页html文件中插入java程序段和jsp标记,从而形成jsp文件。 用jsp开发的web应用是跨平台的,即能在linux下运行,也能在其他操作系统上运行。jsp技术使用java编程语言编写类xml的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。jsp将网页
8、逻辑与网页设计和显示分离,支持可重用的基于组件的设计,使基于web的应用程序的开发变得迅速和容易。 web服务器在遇到访问jsp网页的请求时,首先执行其中的程序段,然后将执行结果连同jsp文件中的html代码一起返回给客户。插入的java程序段可以操作数据库、重新定向网页等,以实现建立动态网页所需要的功能。 jsp与java servlet一样,是在服务器端执行的,通常返回该客户端的就是一个html文本,因此客户端只要有浏览器就能浏览。 jsp页面由html代码和嵌入其中的java代码所组成。java servlet 是jsp的技术基础,而且大型的web应用程序的开发需要java servle
9、t和jsp配合才能完成。jsp具备了java技术的简单易用,完全的面向对象,具有平台无关性且安全可靠,主要面向因特网的所有特点。 1jsp技术的强势 (1)一次编写,到处运行。在这一点上java比php更出色,除了系统之外,代码不用做任何更改。(2)系统的多平台支持。基本上可以在所有平台上的任意环境中开发,在任意环境中进行系统部署,在任意环境中扩展。相比asp/php的局限性是现而易见的。 (3)强大的可伸缩性。从只有一个小的jar文件就可以运行servlet/jsp,到由多台服务器进行集群和负载均衡,到多台application进行事务处理,消息处理,一台服务器到无数台服务器,java显示了
10、一个巨大的生命力。 (4)多样化和功能强大的开发工具支持。这一点与asp很像,java已经有了许多非常优秀的开发工具,而且许多可以免费得到,并且其中许多已经可以顺利的运行于多种平台之下。 2 jsp技术的弱势 (1) 与asp一样,java的一些优势正是它致命的问题所在。正是由于为了跨平台的功能,为了极度的伸缩能力,所以极大的增加了产品的复杂性。 (2) java的运行速度是用class常驻内存来完成的,所以它在一些情况下所使用的内存比起用户数量来说确实是“最低性能价格比”了。从另一方面,它还需要硬盘空间来储存一系列的.java文件和.class文件,以及对应的版本文件。1.3.2 数据库my
11、sql mysql是一个小型关系型数据库管理系统,开发者为瑞典mysqlab公司,在2008年1月16号被sun 公司收购。mysql被广泛地应用在internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了mysql作为网站数据库。如雅虎、阿尔卡特朗讯、google公司、诺基亚公司、百度等公司就采用了mysql数据库。mysql数据库可以称得上是目前运行速度最快的sql语言数据库。除了具有许多其它数据库所不具备的功能和选择之外,mysql数据库是一种完全免费的产品,用户可以直接从网上下载.mysql数据库主要有
12、以下特点:1、可移植性使用c和c+编写,并使用了多种编译器进行测试,保证源代码的可移植性。2、可扩展性和灵活性mysql可以支持unix、linux和sun os以及windows等多种操作系统平台。在一个操作系统中实现的应用可以很方便地移植到其他操作系统。mysql作为开源性质的 数据库服务器,可以为那些想要增加独特需求的用户提供完全定制的功能。3、强大的数据保护功能mysql有一个非常灵活且安全的权限和密码系统。为确保只有获授权用户才能进入该数据库服务器,所有的密码传输均采用加密形式,同时也提供了 ssh和ssi。支持,以实现安全和可靠的连接。mysql强大的数据加密和解密功能,可以保证敏
13、感数据不受未经授权的访问。4、支持大型的数据库虽然对于用php编写的网页来说,只要能够存放数百条以上的记录数据就是够了,但mysql可以方便地支持上千万条记录的数据库。作为一个开放源代码的数据库,mysql可以针对不同的应用进行相应的修改。5、超强的稳定性mysql拥有一个非常快速而且稳定的基于线程的内存分配系统,可以持续使用而不必担心其稳定性。线程是轻量级的进程,它可以灵活地为用户提供服务,而不占用过多的系统资源。用多线程和c语言实现的mysql能很容易地充分利用cpu。6、强大的查询功能mysql支持查询的select和where语句的全部运算符和函数,并且可以在同一查询中混用来自不同数据
14、库的表,从而使得查询变得快捷、方便。1.3.3 tomcat介绍tomcat 服务器是一个免费的开放源代码的web 应用服务器,是apache 软件基金会的jakarta 项目中的一个核心项目,由apache、sun 和其他一些学校及个人共同开发而成。由于有了sun 的参与和支持,最新的servlet 和jsp 规范总是能在tomcat 中得到体现,tomcat 5 支持最新的servlet 2.4 和jsp 2.0 规范。因为tomcat 技术先进、性能稳定,而且免费,因而深受java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的web 应用服务器。tomcat 很受广大程序
15、员的喜欢,因为它运行时占用的系统资源小,扩展性好,支持负载平衡与邮件服务等开发应用系统常用的功能;而且它还在不断的改进和完善中,任何一个感兴趣的程序员都可以更改它或在其中加入新的功能。tomcat 是一个小型的轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试jsp 程序的首选。对于一个初学者来说,可以这样认为,当在一台机器上配置好apache 服务器,可利用它响应对html 页面的访问请求。实际上tomcat 部分是apache 服务器的扩展,但它是独立运行的,所以当你运行tomcat 时,它实际上作为一个与apache 独立的进程单独运行的。 自从jsp发
16、布之后,推出了各式各样的jsp引擎。apache group在完成gnujsp1.0的开发以后,开始考虑在sun的jswdk基础上开发一个可以直接提供web服务的jsp服务器,当然同时也支持servlet, 这样tomcat就诞生了。 tomcat是jakarta项目中的一个重要的子项目,其被javaworld杂志的编辑选为2001年度最具创新的java产品,同时它又是sun公司官方推荐的servlet和jsp容器,因此其越来越受到软件公司和开发人员的喜爱。servlet和jsp的最新规范都可以在tomcat的新版本中得到实现。其次, tomcat也是完全免费的软件,任何人都可以从互联网上自由
17、地下载。第二章 系统分析2.1 现状分析传统的考试方式是教师提前命题、印刷试卷、组织学生考试、学生在统一时间和地点考试、收卷后教师阅卷、成绩统计。如图2.1组织学生考试印刷试卷教师提前命题成绩统计教师阅卷学生统一考试图2.1 传统考试模式这种模式存在有较多的问题:命题:由于是同意的时间进行考试,所以考生的试卷都是一样的,这样对教师命题带来的很大的麻烦,即:试题太难或者太容易,都达不到考试的目的。如果是大型的考试,比如英语四级考试,还要担心试题是否被泄漏的等问题(现在已经有类似问题的出现,才会有现在说的花卷)。印刷试卷:组织考试,印刷试卷费工费时,成本高,而且对于纸张资源也是一种浪费,而且印刷的
18、时候,也会担心试题被泄漏的问题。组织学生考试:监考人资源的浪费,和教师资源的匮乏,如何调配也是一个难题,如果是全国统一考试,还要涉及不同区域同时考试的问题。学生统一考试:由于是同一时间,同一地点,同一张试题,考生作弊问题便会出现,而且是非常难解决的问题,再加上每个监考员监考的严格程度不同,这些人为因素难控制,使考试难公平,公正。教师阅卷:教师阅卷比较容易出错,会造成人为的不公正性。成绩统计:当成绩录入时,数字的混乱会导致录入者输入错误或者看错。2.2 可行性分析可行性分析也称为可行性研究,即是在系统调查的基础上,针对新系统的开发是否具备必要性和可能性,对新系统的开发从技术、经济、管理的方面进行
19、分析和研究,以避免投资失误,保证新系统的开发成功。可行性研究的目的就是用最小的代价在尽可能短的时间内确定问题是否能够解决。该系统的可行性分析包括以下几个方面的内容。2.2.1经济可行性在线考试必然会在今后的教学管理上成为主要的考试形式。开发一套能满足一般考试的需要,并实现试卷生成、评判自动化的在线考试系统。在减少由于人为原因导致试卷阅卷的不公正的同时,也可以让教师的工作量得以减少,有更多的时间去备课教学。本系统如果用在一些辅助教育类的网站上,那经济效果是很明显的;如果是用在学校的教学管理上,会得以发挥其潜在的经济效益,比如印刷试卷的费用等。因此,本系统在经济上是可行的。2.2.2 技术可行性技
20、术上的可行性分析主要分析技术条件是否能顺利完成开发工作,硬、软件能否满足开发者的需要等。硬件方面,硬件的更新速度之快,可靠性越来越高,目前一般的硬件平台均能满足次系统的需要。软件方面,编程的软件以及web服务器等均已具备,并且环境变量已经搭好,数据库用mysql存储大量的数据,mysql开源化,目前已经很成熟,在灵活、安全和易用方面均能提供良好的支持。因此,系统的软件开发平台已经成熟可行。2.3 设计目标在线考试系统的总体目标:1. 本系统提供给管理员类用户、教师类用户及学生类用户使用。不同的用户类型所能完成的功能不同。管理员类用户可以对于已经注册的考生及系统中已经存在的教师进行删除操作,对于
21、未注册过的考生及系统中未存在的教师进行添加操作;教师类用户可以创建试题、删除试题、修改试题,也可进行试题维护、修改密码以及对成绩的统计;学生类用户主要是参与考试,完成试卷,查询成绩。2. 考试数据的存放和处理过程必须保密,需要一定的安全性保障若考生需要查卷,经审核方可以。3. 题目的选择具有稳定性、随机性。稳定性就是每张试卷总体的难易程度要近似一样,保证每一次考试对每一个考生是公平的,随机性可以避免作弊的发生。4. 适时的试题题库更新,试题题型包括判断题、选择题类型。试题库的更新由管理员类用户完成。学生类用户不允许对试题进行更新。5. 实现现代考试网络化。2.4 功能要求系统具备的基本功能:1
22、.用户登录及注册对用户进行识别、验证;没有注册的用户跳转到用户注册页面;2.考试模块考生选择自己想要参加的考试类别,并进行考试,考试完成以后可以获得当考试成绩。3.历史成绩模块-考生可以看到自己以前参加的考试成绩。以对自己的进步状况进行一次把握。4.试题维护模块-教师选择试题的类别,然后针对该试题分类中的所有试题进行维护,可以添加新题目,也可以对现在有的题目进行修改或者删除处理。5.试卷设置模块-教师对题库中的题目按照一定分类标准存放,包括分类的添加、修改和删除操作等。6.历史成绩管理模块-教师可以看到模式体分类的整体考试情况,考试成绩分布情况,可以判断出题库中的题目难以水平,并可以在以后的维
23、护中做出适当调整。7.考生管理-系统管理员可以对已经注册的考生进行删除操作,对于未注册的考生进行增加操作。8.教师管理-系统管理员可以对系统已经存在的教师进行删除操作,对于未在系统中存在的教师进行增加操作。9.修改密码模块-教师和考生可以在已经登录成功的页面点击修改密码,可以修改本人登录此考试系统的登录密码。除了实现上述功能以外,在线考试系统还应该具有简洁、易用的界面,安全性要高,稳定性要强。根据以上的需求分析,画出本系统的use case图,如图2.2所示:管理员 教师管理考试考生管理考试登 录教师注 册试题维护考试考生在线考试考试试卷设置考试历史成绩绩历史成绩管理修改密码图2.2 在线考试
24、系统的use case图2.5 系统开发环境配置1. 操作系统:windows xp 2. 内存:4g3. cpu:2.00ghz4. java平台:jdk 5.05. web服务器:tomcat6.06. 数据库服务器:mysql7. 开发平台: myeclipse6.0第三章 系统设计3.1数据库设计在对网上考试系统数据库部分进行设计的过程中,通过对系统功能进行需求分析得到系统的基本信息表,详细设计过程如下介绍。3.1.1 数据库需求分析需求分析是设计数据库的起点,需求分析的结果是否准确地反映了用户的实际要求,将直接影响到后面各个阶段的设计,并影响到设计结果是否合理和实用。对于本系统而言,
25、系统的角色分为管理员、教师、学生,这需要3个表,而考生考试,需要一个存放题库的表,考试的类别不同,也需要一个存放类别的表,考生考试完毕后,需要一个存放考试成绩的表。综合以上分析,要实现上面的所有功能模块,数据库共要设计六个表,它们分别是:试卷类别表、用户表、用户成绩表、教师表、管理员表、题库表。3.1.2 数据库表设计用户信息表,用来存放考生信息,如表3-1所示:表3-1用户信息表字段名类型长度是否为主键可否为空说明user_idint11是否用户的idusernamevarchar20否否登录用户名passwordvarchar20否否用户登录密码realnamevarchar20否否用户真
26、实姓名教师信息表,存放教师信息,如表3-2所示:表3-2教师信息表字段名类型长度是否为主键可否为空说明teacher_idint11是否教师的idteachernamevarchar20否否教师登录名passwordvarchar20否否教师登录密码realnamevarchar20否否教师真实姓名管理员信息表,存放管理员信息,如表3-3所示:表3-3管理员信息表字段名类型长度是否为主键可否为空说明adusernamevarchar20是否管理员登录名passwordvarchar20否否管理员登录密码realnamevarchar20否否管理员真实姓名题库信息表,存放考试题目以及答案等信息,
27、如表3-4所示:表3-4题库信息表字段名类型长度是否为主键可否为空说明question_idint10是否试题编号category_idint10否否试题分类编号subjectvarchar300否否题目choice_avarchar100否否选项achoice_bvarchar100否否选项bchoice_cvarchar100否否选项cchoice_dvarchar100否否选项danswerchar10否否正确答案成绩表,存放考生考试时间以及成绩等信息,如表3-5所示表3-5成绩表字段名类型长度是否为主键可否为空说明record_idint10是否考试记录编号usernamevarcha
28、r20否否考试用户名category_idchar10否否试题分类编号test_timechar14否否考试时间test_resultint11否否考试成绩试卷类别表,存放试卷类别信息,包括试卷分类名称、试卷题目等,如表3-6所示表3-6试卷类别表字段名类型长度是否为主键可否为空说明category_idint11是否试题分类编号category_namevarchar20否否试题分类名称question_numberint10否否试题数目3.1.3数据库逻辑结构设计1 关系图本系统各表之间的关系如下图3-1示: 图3-1关系图2完整性设计完整性要求用于描述各种信息之间的制约关系以及关联关系,
29、各个数据项的取值范围以及各个数据项是否可以取值。根据实际需要,采取一定的手段来满足用户的完整性需求。域完整性约束要求属性值必须在域中。实体完整性约束要求主键必须唯一且不能为空。如用户信息表中的用户名设置为主键,并且要求唯一且不能为空。3.2系统结构设计网上考试系统是一个典型的数据库应用程序,主要有管理员、教师和学生三大模块组成,各模块功能如下:管理员模块:该模块包含2个功能,一个为考生管理,系统管理员可以对已经注册的考生进行删除操作,对于未注册的考生进行增加操作;另一个为教师管理,系统管理员可以对教师进行增加、删除操作。教师模块:该模块包含4个功能,分别为试卷设置、试题维护、历史成绩、修改密码
30、。教师成功登录该系统后,能够进行修改个人信息,添加、修改、删除试题、试卷类别操作,也可对考生的成绩进行统计。学生模块:该模块包含3个功能,分别为开始考试、历史成绩、修改密码。学生成功登录该系统后,能够进行考试、查询成绩、修改密码。系统功能结构如图3-2所示: 系统功能教师模块管理员模块学生模块开始考试修改密码试题维护试卷设置历史成绩考生管理教师管理历史成绩修改密码图3-2系统功能结构图3.3用户界面设计页面上部采用一个logo图片和适当的标识,表明当前的系统名称。接下来是帮助连接和退出系统的连接。然后下部页面的主题分为左右两部分,左边是导航模块部分,其中放置迁移到不同功能模块的链接按钮,右边是
31、页面的主要操作区域,不同页面的不同显示主要在此体现。学生角色的模版页面如图3-3所示:在线考试系统logo图片。 帮助 退出登录欢迎您!xxx开始考试历史成绩修改密码图3-3 学生角色模版每个模块都包含多个页面,再次挑选几个比较低型或者重要的页面进行详细描述。其他的页面结构比较类似或者比较简单,不一一详述。学生开始考试的时候,首先需要选择试卷类型,或者也可以叫做试题分类。在此页面中采用下拉列表框的形式进行,如图3-4所示:在线考试系统logo图片。 帮助 退出登录欢迎您!xxx请选择试题的分类:确定会计基础 开始考试历史成绩修改密码图3-4 试题分类选择页面草图选择试题分类以后,即是学生答题页
32、面。答题页面的主体应该是试题和试题的选项。考虑到本系统需要在题目结束以后立即知道考试结果,所以决定采用所有试题的形式都是abcd型的选择题,页面应该针对这些题目选项设置单选按钮。在答题内容的上方,应该能够给考生信息,说明当前的题目是全部题目的第几道,以及总共有几道题,使得考生可以把握整个考试进度。同时考虑到考生在时间允许的情况下,需要在题目间前后迁移,所以在题目的下方,还应该有前后翻页的按钮。对应教师角色的模版略有不同,模块多了几个,而且页面顶端的标识也有所区别。对应的模版页面如图3-5所示。在线考试系统(管理界面)logo图片。 帮助 退出登录欢迎您!xxx试题维护试卷设置成绩查询修改密码图
33、3-11 教师角色模版页面图3-5 管理员角色模版页面第四章 系统实现本系统包括3个不同的角色,即学生、教师、管理员。不同角色的功能有所不同,学生的功能包括:考试模块,修改密码,成绩查询模块。教师的功能包括:试卷类别管理、试题管理、修改密码、成绩管理。管理员的功能包括:教师管理和考生管理。4.1 数据库连接的实现方法从系统功能模块划分中可以看出,各模块虽然是独立的,但又统一于同一数据库中,便于管理员管理维护数据库,同时也便于教师和学生的操作。在介绍系统各模块的实现方法之前,首先介绍系统与mysql数据库的连接方法,再介绍系统主要部分的实现方法。创建与数据库的连接:首先要将mysql的驱动包放在
34、tomcat/lib目录下;:利用语句进行对数据库的操作,以下仅是对用户表查询的语句:<%page contenttype="text/html;charset=gb2312" %><%page language="java" import="java.sql.*" %><%/声明数据库连接对象,初始化为空connection conn = null;statement stmt = null;resultset rs = null;try /载入mysql的jdbc驱动类 class.forname(&
35、quot;com.mysql.jdbc.driver"); /获得数据库连接 string sconn = "jdbc:mysql:/localhost/myexam?user=root&password=890427" conn = drivermanager.getconnection( sconn ); /创建statement对象 stmt = conn.createstatement(); /执行sql语句 string query = "select * from user" rs = stmt.executequery(
36、query );%> catch(exception e)/获得数据库连接出错 system.out.println("error occured!");finally /释放数据库连接 rs.close(); stmt.close(); conn.close();%>4.2 登陆注册模块4.2.1 登录模块用户登录页面比较简单,为防止用户登录的操作错误,应设置错误处理页面,在登录操作过程中,一般发生的错误有:用户输入了错误的用户名或密码、用户直接单击了登录按钮,对上述情况的判断就要通过servlet文件来实现。当用户登录的时候,输入的帐号或者密码有其中一项为空
37、时,会有提示框提示,提示您帐号或者密码不能为空。实现这个功能的是用javascript实现的,具体代码如下所示:验证输入不为空的脚本代码 <script type="text/javascript"> 定义了一个名为checkform的查询表单函数function checkform(form) 、如果value为空,会提示帐号不能为空if(form.teachername.value="") alert("账号不能为空"); 让form表单中的teachername控件获得焦点(光标),回到输入框位置。form.teac
38、hername.focus();return false; if(form.password.value="") alert("密码不能为空"); form.password.focus(); return false; return ture; </script>在登录页面时,当用户提交了登录资料后,就由“loginvc.jsp”这个页面进行验证,它的工作主要是连接到数据库,从数据中找出输入的用户名和密码并判断其是否一致。如果用户输入了错误的用户名和密码,就会跳出一个登录失败的页面。用户可以点击返回按钮回到其刚才登录的界面,然后重新输入用户
39、名及密码进行再次登录。若用户提交正确的用户和密码后,如果记录验证无误,就通过jsp重定向语句response.sendredirect()跳转到相应的主界面。教师以及管理员的登录验证跟考生相似,只是查询条件和连接的数据库表不同,以及登陆成功之后,跳转的页面不同。4.2.2 考生注册模块在此模块,考生需要填写用户名、密码、确认密码、真实姓名。如若填写中缺少一项,那么会有提示,其功能也是由上面所说的一样,通过调用javascript实现的,这里只提供下截图,主要代码如上,如图4-1所示:图4-1 注册提示页面当用户填写的内容完全符合注册标准后,点击注册按钮,会转到注册成功的页面;如若用户名已经被注
40、册,会转到注册失败页面,提醒注册用户可能是该用户名已经注册。在此只以注册成功的页面为例,如图4-2所示:图4-2 注册成功页面完成注册模块的主要代码如下所示:首先获取上个页面传过来的数据,用户名、密码、真实姓名string username = request.getparameter("username"); string password = request.getparameter("password"); string realname = request.getparameter("realname");out.printl
41、n(username);/打印出username其次开始连接数据库 try class.forname( "com.mysql.jdbc.driver" ).newinstance(); connection conn=drivermanager.getconnection("jdbc:mysql:/localhost:3306/myexam?user=root&password=890427&useunicode=true&characterencoding=gbk"); statement stmt=conn.createst
42、atement(); resultset rs=null;查询user表,看用户名是否存在 string sql="select * from user where username like '"+username+"'" rs=stmt.executequery(sql); 如果存在,提示“ 您好,您注册的用户名已经存在,请重新输入 ”,如果不存在,把接收过来的值付给新的变量: string s_username=request.getparameter("username"); string s_password
43、=request.getparameter("password"); string s_realname=request.getparameter("realname"); 执行sql插入语句,把得到的值插入到user表中sql = "insert into user(username,password,realname) value('"+username+"','"+password+"','"+realname+"')"如
44、果插入成功,提示:“恭喜您注册成功!” 4.3考生模块考生登录系统并且用户名也密码正确后,会直接跳转到学生主页,本页面中,考生可以在左侧选择自己下一步要做的事情,有开始考试、历史成绩查询、修改密码。在页面中间,有提示语,告诉考生每个按钮都可以操作什么功能;若考生对考试流程不太熟悉,可以点击帮助,来查询相关问题的答案。如图4-3所示:图4-3考生主页4.3.1 开始考试模块考生点击开始考试,会首先弹出关于所选考试科目的一些介绍,比如考试时间和总共有多少道题目等,然后点击开始考试,倒计时开始,考生选择上一题,下一题进行答卷,当考生答到最大题数时,下一题变成完成答卷按钮。点击完成答卷,进入成绩页面,
45、考生可以知道自己的成绩,并且,成绩通过后台,插入到数据库中。如图4-4所示:图4-4 考生考试页面执行的具体代码如下所示:<% httpsession sess=(httpsession)request.getsession(true); int category = (integer)sess.getattribute("category");string username = request.getparameter("username"); mysqldjtdao md = new mysqldjtdao(); /引进包 int valid
46、= md.selecttestrecordbyuser(username,category);/去test_record表查询有无考试记录 valid=0;/控制返回值,自己可以自由修改。 if( valid=0 ) calendar cl = calendar.getinstance();/java util 包 表提供的系统时间calendar long starttime = cl.gettimeinmillis();/得到当前时间的毫秒数 long endtime = starttime+1800000; sess.setmaxinactiveinterval(3600); /设置se
47、ssion的存活时间 sess.setattribute("username",username); sess.setattribute("endtime",endtime); list<integer> tmid = new arraylist<integer>();/指定传入的类型 建立一个集合 准备存放抽到的题目的id号 tmid.add(0);/设置默认值0 sess.setattribute("tmid",tmid); int fenshu =0; sess.setattribute("fe
48、nshu",fenshu); list<integer> ddcount = new arraylist<integer>(); sess.setattribute("ddcount",ddcount); list<question> allwts = new arraylist<question>();/建立问题question对应的实体类 来存放查到的题目信息 list<integer> listsid = md.selectqinfocount(category);/某个科有多少个问题 int qn
49、um = md.selectqnum(category);/共需要几个问题 sess.setattribute("qnum",qnum); random rand = new random();/java提供的得到数字的类 for( int a=0;a<qnum;a+ )/开始抽题 int hao = rand.nextint(listsid.size()-1);/取一个随机数,不超过题目的总数 rand.nextint()取一个随机数 for( integer vd:tmid )/去掉重复的题 泛型循环 if( vd=hao ) hao = rand.nextint
50、(listsid.size()-1);/如果重复再重新抽,即重新生成一个随机数 int bcid = listsid.get(hao);/根据抽到的数得到该题目的id号 question qs = md.selectqinfobyid(bcid);/根据id号查询题目的信息 allwts.add(qs);/把查到的题目的信息插入到allwts集合中 tmid.add(hao);/把已经用过的随机数放入集合,防止重复抽题 sess.setattribute("allwts",allwts);%> <jsp:forward page="questionen
51、ter.jsp" /> <% else request.setattribute("errorinfo","已经答过题了,不能重复答题!"); %> <jsp:forward page="endqdg.jsp" /> <% %>4.3.2 历史成绩模块考生点击历史成绩,会先迁移到考试科目选择页面,当考生通过下拉列表,选中要查询的科目,然后点击确认,会从数据库中提取出考生的成绩,然后在表格中显示。点击左下角的返回按钮,回到考试科目选择页面,继续查询其他科目成绩,如图4-5所示:图4-5
52、 考生成绩查询页面成绩查询页面主要代码如下所示:接收上个页面传过来的值 string category = request.getparameter("category"); string result = null; int count = 0; 开始连接数据库 class.forname( "com.mysql.jdbc.driver" ).newinstance(); connection conn=drivermanager.getconnection("jdbc:mysql:/localhost/myexam?user=root&am
53、p;password=890427&useunicode=true&characterencoding=gbk"); statement stmt=conn.createstatement(); 数据库结果集的数据表 resultset rs=null; resultset rr = null;执行sql语句,查询test_record表中是否有与接收的值相同项 string sqlcount = "select count(*) from test_record where (category_id='"+category+"&
54、#39; and username ='"+s+"')" rr = stmt.executequery(sqlcount); if(rr.next()将rr.getstring字符类型数据转换为integer整型数据 count = integer.parseint(rr.getstring(1); 定义一个新的字符串数组 result = new stringcount; 执行sql语句,查询test_record表 string sql = "select * from test_record where (category_id='"+category+"'and username =&
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年运动医学康复题库及答案
- 2025年全国初二语文试卷及答案
- 2024-2025学年滨州科技职业学院单招《职业适应性测试》能力检测试卷附完整答案详解(名师系列)
- 2025微信支付业务推广合同
- 2024-2025学年监理工程师模拟题库附答案详解【研优卷】
- 2023年度邮政行业职业技能鉴定能力提升B卷题库含答案详解【巩固】
- 2024年质量员复习提分资料【综合卷】附答案详解
- 浙江金华市教育局所属事业单位金华市教育教学研究中心选调4人笔试高频难、易错点备考题库及答案详解一套
- 2024计算机四级模拟试题附答案详解【能力提升】
- 2023年度职称计算机模考模拟试题及参考答案详解【突破训练】
- 18米固定式高杆灯
- 临时起搏器植入术后护理(心血管内科)
- 有机化学饱和烃课件
- GB/T 30707-2014精细陶瓷涂层结合力试验方法划痕法
- GB/T 26536-2011竹条
- 公司付款委托书 模板
- 全屋定制基础知识培训课件
- 设备安装施工方案
- 危险化学品作业场所安全、危险象形图、方向辅助标志、警戒线、警示语句、图形标志尺寸、基本形式
- 可测试性设计DFT课件
- 排污许可证管理培训
评论
0/150
提交评论