《网上在线考试系统设计毕业论文.doc》由会员分享,可在线阅读,更多相关《网上在线考试系统设计毕业论文.doc(27页珍藏版)》请在三一办公上搜索。
1、摘要2关键字:考试系统 ASP.NET ADO.NET SQL Sever 2000 Browser/Server2第一章 绪论31.1 网上考试系统的现状分析31.2 选题的背景及研究意义41.3 系统基本简介4第二章 系统的关键技术及介绍62.1 ASP.NET技术概况62.1.1 ASP.NET的优势62.1.2 常用到的ASP.NET内置对象82.2 利用SQL Sever 2000来建立数据库82.3 Browser/Server模式本系统的开发模式92.3.1 Browser/Server模式简介92.3.2 Browser/Server模式的特点102.4 ADO.NET对象模型
2、112.5 系统数据库设计132.5.1 数据库结构及说明132.5.2 用户权限简介14第三章 系统的整体分析与设计163.1 需求分析163.1.1 系统需要解决的主要问题163.1.2 系统功能模块划分163.2 总体设计173.2.1 公共登陆模块设计183.2.2 在线考试模块设计183.2.3 管理员功能模块设计19第四章 部分页面实现详解204.1 考试页面的实现204.2 管理主页面的实现224.3 学生信息管理页面(manstudentinfo/)的实现224.3.1 添加、修改学生信息(addstudentinfo/)24致谢26参考文献27摘要:随着网络的普及和对教育的重
3、视,各院校各学科的网上考试都具有了必要的使用环境。但是,目前国内的一些网络教学系统的主要功能是教学,不能单独作为考试平台,通用性差,而且系统中对主观题的评阅多是采用人工评阅方式,没有实现真正意义上的自动评分。另一方面,我们所在院校的计算机基础课已开设了多年,但尚在沿用传统的考试形式或使用单机版的考试系统。基于Web的网上考试系统的设计与实现就是基于上述目的开发设计的。本系统采用B/S架构作为系统的总体结构,以Web数据库技术为依托,利用微软的ASP.NET技术,结合ADO,实现了对Web数据库的访问和查询。该设计实现了按题型随机抽题组卷、在线考试、题库管理、系统管理的功能,能够对客观题在线评分
4、。学生用学号登录成功后,阅读考试须知,之后选择考试科目进入考试页面,完成相应科目考试,自动给出考试成绩。系统管理,实现了对题库、考生信息、考试成绩、考试科目的管理。题库管理,实现了对试题的添加、编辑、删除功能;考生信息管理可以添加、修改、删除、查询考生信息,成绩管理可以删除成绩信息,科目管理主要是修改考试科目信息。基于Web的网上考试系统本身是一个很大的系统,尤其试题库部分需要许多人的参与以及大量的投入才能建成。该系统虽然仅仅是完成计算机文化基础和操作系统课程的考试,但却具有良好的实用性与通用性,提供友好的人机界面,具有较好的可扩充性和开放性。 关键字:考试系统 ASP.NET ADO.NET
5、 SQL Sever 2000 Browser/Server 第一章 绪论1.1 网上考试系统的现状分析 在信息技术迅速发展的今天,网络对于大多数人已不再陌生,并且其应用在人们的工作、学习和生活中越来越多地发挥着不可替代的作用。近年来随着软件工程技术、信息通信技术的快速发展以及计算机网络技术的日趋成熟,网络教育在人们的教育活动中逐步得到普及。网上考试是网络教育不可缺少的组成部分,是网络教育的一个重要环节。网上考试在国外一些国家已经得到了蓬勃发展,人们选学课程和考试都是通过网上进行的。例如国外一些著名的考试,如Microsoft公司的MCSE(Microsoft系统工程师认证考试)、GMAT(工
6、商管理硕士入学考试)、托福考试、GRE(美国研究生入学考试)等,都是采用网上考试的形式进行的。在国内,目前绝大多数考试还停留在传统考试方式上,对互联网的真正应用仅限于一些考试的网上报名工作和网上成绩查询,还没有真正形成网上考试规模。网上考试系统作为现代教育的一个子系统,是保证教育教学质量的重要手段。在传统的考试方式下,组织一次考试要经过出题、考试、评卷、试卷分析等步骤,随着考试类型的增加及考试要求的提高,教师的工作量将会越来越大,并且其工作非常容易出错,在一定程度上说,传统的考试方式已经存在着改革的必要了。Internet技术的发展使得考试的技术手段和载体发生了划时代的变化,考试从传统的纸笔考
7、试到计算机辅助考试再发展到基于Web的网上考试成为现实。现阶段,网上考试系统的主流开发技术已经相当成熟,且很好地适应了动态站点设计和基于Web的数据库访问的要求,是当前网上考试软件实现的主流技术之一。在对大量关于网上考试系统资料的研究和学习后,根据工作的需要,针对本校实际情况特别是教学的需求,利用学校校园网已有的基础条件,研究开发适合本校使用的基于Web的网上考试系统。1.2 选题的背景及研究意义 随着计算机科学、网络技术的迅猛发展,在教育领域里,实现网上考试可以充分利用学校现有的计算机软、硬件资源和网络资源实现考试;对于客观题由计算机来完成阅卷,可以将减少人工阅卷的工作量。目前常用的网上考试
8、系统主要有两种基本模式:传统的C/S(客户机/服务器)模式和新型的B/S(浏览器/服务器)模式,所谓C/S模式,即数据库(比如,试题库)内容放在远程的服务器上,在客户机上安装相应软件;C/S结构在技术上虽然很成熟,但该结构的程序往往只局限在小型的局域网内部,不利于扩展。并且,该结构的每台客户机都需要安装相应的客户端程序。当拥有用户量比较多时,如果采用该结构,系统的安装与维护工作比较繁重。同时,由于应用程序直接安装在客户机,客户机直接和数据库服务器交换数据,系统的安全性也受到一定影响。与传统的基于C/S模式的网上考试系统相比,B/S体系将应用逻辑与用户界面和数据访问相分离,使系统的维护变得简单(
9、只需要改变网页,即可实现所有用户的同步更新),同时简化了客户端的功能,用户只需浏览器即可使用此考试系统,更适宜于互联网上的考试。在信息网络化的现实面前,我们提出一种基于Web的网上考试系统,并用SQL Sever 2000数据库与ASP.NET技术结合进行了该系统的开发。1.3 系统基本简介 我们课题组所做的工作不仅仅是参与开发一个完整的在线考试系统,也是一个引导性的基础研究,是对.net平台下基于B/S结构的软件体系结构、关键技术、实现技术、框架解决方案进行的探索。本系统采用ASP.NET、HTML、Javascript、VBScript、图形编辑与数据库等工具,通过基于WEB服务器访问WE
10、B页面,可以不受地点,时间限制,通过宽带上网或其它上网方式,借助Internet这一强大、方便的工具,考生可以在互联网上通过浏览器来选择科目、参加考试,管理员可以在互联网上通过浏览器来添加、修改学生信息,添加、修改、删除试题,修改考试科目信息,管理学生成绩;同时还实现有学生信息查询功能:按班级、学号、姓名等关键字查询,实现对整个系统的管理功能。 系统的主界面主要有考生、管理员入口,根据用户类型,分别进入考试和管理两个不同的页面。其最大的特点是开放性、方便性和灵活性。第二章 系统的关键技术及介绍在基于Web的网上考试系统的设计过程中,主要考虑了以下几方面的问题:1) ASP.NET技术;2) 建
11、立数据库,使用SQL Sever 2000来建立;3) 选择系统的开发模式,B/S模式;4) ADO.NET对象模型;5) 系统数据库设计。2.1 ASP.NET技术概况 ASP.NET是微软公司推出的一种Internet编程技术,它采用效率较高的、面向对象的方法来创建动态Web应用程序。在原来的ASP技术中,服务器端代码和客户端HTML混合在一起,常常导致页面的代码冗长而复杂,程序的逻辑难以理解。ASP.NET是一种独立于浏览器的编程模型,可以在最新版本的IE、NetscapeNavigator以及诸如Opera等被广泛使用的浏览器上运行。ASP.NET是一种建立在通用语言上的程序构架。一个
12、已编译的、基于.NET的环境,把基于通用语言的程序在服务器上运行。将程序在服务器端首次运行时进行编译,比ASP即时解释程序速度上要快很多。微软公司发布了包括Visual Basic.NET、C#.NET、Visual C+.NET等与.NET兼容的语言来创作应用程序。2.1.1 ASP.NET的优势 ASP.NET是在服务器上运行的编译好的公共语言运行库代码,它可利用早期绑定、实时编译、本机优化和盒外缓存服务。这相当于在编写代码行之前便显著提高了性能。1)世界级的工具支持ASP.NET框架补充了Visual Studio集成开发环境中的大量工具箱和设计器。WYSIWYG编辑、拖放服务器控件和自
13、动部署只是这个强大的工具所提供功能中的少数几种。2)威力和灵活性由于ASP.NET基于公共语言运行库,因此Web应用程序开发人员可以利用整个平台的威力和灵活性。Microsoft.NET框架类库、消息处理和数据访问解决方案都可从Web无缝访问。ASP.NET也与语言无关,所以可以选择最适合应用程序的语言,或跨多种语言分割应用程序。另外,公共语言运行库的交互性保证在迁移到ASP.NET时保留基于COM的开发中的现有投资。3)简易性ASP.NET使执行常见任务变得容易,从简单的窗体提交和客户端身份验证到部署和站点配置。例如,ASP.NET页框架使您可以生成将应用程序逻辑与表示代码清楚分开的用户界面
14、,和在类似Visual Basic的简单窗体处理模型中处理事件并不相同。另外,公共语言运行库利用托管代码服务(如自动引用计数和垃圾回收)简化了开发。4)可管理性ASP.NET采用基于文本的分层配置系统,简化了将设置应用于服务器环境和Web应用程序。由于配置信息是以纯文本形式存储的,因此可以在没有本地管理工具帮助的情况下应用新设置。此“零本地管理”哲学也扩展到了ASP.NET框架应用程序的部署。只需将必要的文件复制到服务器,即可将ASP.NET框架应用程序部署到服务器。不需要重新启动服务器,即使是在部署或替换运行的编译代码时。5)可缩放性和可用性ASP.NET在设计时考虑了可缩放性,增加了专门用
15、于在聚集环境和多处理器环境中提高性能的功能。另外,进程受到ASP.NET运行库的密切监视和管理,以便当进程行为不正常(泄漏、死锁)时,可就地创建新进程,以帮助保持应用程序始终可用于处理请求。6)自定义性和扩展性ASP.NET随附了一个设计周到的结构,它使开发人员可以在适当的级别“插入”代码。实际上,可以用自己编写的自定义组件扩展或替换吉林大学硕士学位论文ASP.NET运行库的任何子组件。7)安全性借助内置的Windows身份验证和基于每个应用程序的配置,可以保证应用程序是安全的。2.1.2 常用到的ASP.NET内置对象 Application对象:对整个ASP.NET执行环境而言,一个虚拟目
16、录下的所有ASP.NET程序构成了一个Web应用程序。在多任务执行的情况下,来自四面八方的众多用户可能执行同一个Web应用程序,这便依赖Application对象。常用到的场合:聊天室、网页计数器等。Request对象:获取从客户浏览器传给服务器端的数据,如接收来自表单的数据。Response对象:Request对象与Response对象就像一般程序语言里的Input及Output命令,若要让服务器端的ASP.NET程序能够接收来自客户端的信息,须用Request对象;若想将服务器端的信息传递给客户端,须用Response对象。适用于同一位用户,换句话说,一个Session对象只属于一位用户。
17、常用到的场合:虚拟购物车、用户登陆网站时用户名的临时存储等。 2.2 利用SQL Sever 2000来建立数据库 Microsoft SQL Server 2000 是一种关系型数据库。此种数据库采数据分类表格化的架构,将相关的数据组成表格,表格和表格之间可以有关联性,因此称为关系型数据库。系统管理员可透过应用程序进入服务器,更改数据型态,管理及处理服务器资源。SQL Server 也是一种具备延展性的数据库(scalable database),亦即 SQL Server 可以支持多位使用者同时进入数据库中处理大量的数据。如图2-1所示:图2-1 SQL Server 2000工作方式2.
18、3 Browser/Server模式本系统的开发模式 2.3.1 Browser/Server模式简介 随着网络规模的日益扩大,应用程序的复杂程度不断提高,传统的数据库应用架构已经不能胜任。为了充分利用网络资源,越来越多的信息需要在 www(WoridWideWeb)上发布,实现信息最大程度的共享。Browser/Serve结构伴随着Intemet的发展而很快地发展起来。Browser/Serve体系结构是一种三层结构,其三级结构组成如图2-2所示:图2-2 B/S结构示意图第一层,浏览器是表示层,完成用户接口功能。在客户端向URL(Uniform ResourceLocator)指定的web
19、服务器提出服务器请求,Web服务器用HTTP协议把所需文件资料传给用户,客户端接受并显示在WWW浏览器上。第二层,Web服务器是功能层,完成客户的应用功能。即Web服务器接受客户请求,以CGI或ASP与数据库连接,进行申请处理,而后数据库结果返回web服务器,再传至客户端。第三层,数据库服务器是数据层。数据库服务器应客户请求独立地进行各种处理。Browser/server系统中的Browser作为一种通用的浏览器,一般没有任何应用程序; Browser/server系统中的中间层是B/S结构中相当关键的部分,中间层在Browser/Serve:系统中充当着双重身份:从Browser的角度看,它
20、是 WebServer,而从 DBServe的角度看,它是一个功能丰富的Client。2.3.2 Browser/Server模式的特点 B/S系统的这三层体系结构的特点:友好、统一的图形用户界面在Browser/Server系统中,由于遵循了统一的标准协议,而且使用浏览器作为统一的客户软件,用户无须再花费大量的时间与精力去学习和熟悉不同的系统的使用方法,用户可以把大部分的精力集中在系统的内容上,而不是去记住系统的使用说明书。减少网络中的数据流量在Browser/server系统中,由于数据的处理工作是由服务器来执行的,因此在读取数据和保存数据时,这些数据只在几台服务器之间传输,不需要通过浏览
21、器与服务器之间的网络。一般来说,浏览器与服务器之间的网络大都是距离较长而且速度较低的,而服务器与服务器之间的网络则是距离较短而且速度较高的,因此采用Browser/Server后,可以充分地利用服务器之间的高速连接通路,而减少在浏览器与服务器之间的长距离低速网络中的数据流量。更好的开放性开放性是发挥分布式系统优势的基本保障,它为不同厂商生产的产品协同工作创造了条件,但是这些产品还应当遵循统一的标准。在Browser/server系统中,采用了一致的HTTP协议以及其他一些共同的规则,不同系统之间的冲突将会大大减少。平台无关性在Browser/Server系统中,程序的主体分布在Mid-Serv
22、er上,客户机上只有一个标准的浏览器,它与服务器之间采用标准的TCP/IP及HTTP等协议进行通信,因此客户端的平台是相对独立的,它不依赖于服务器方所采用的软硬平台。用户可以自由地选择自己熟悉的平台进行工作。有效地解决异种数据库联合使用的问题在Browser/Serve系统中,由于采用了 Browser/Mid-Server/Server的三层体系结构,只需在中间层服务器上安装数据库的驱动程序,或者使用专门的服务器用作与数据库连接的桥梁。因为程序的主体是运行在中间服务器上的,客户端只是一个浏览器,避免了在客户端重复安装数据库驱动程序的问题,从而可以有效地解决异种数据库联合使用的问题。客户端的维
23、护工作简单Brower/Serve系统中,由于采用了通用的客户软件,维护工作主要集中在服务器端,而服务器是由专门的管理人员集中管理的,对系统的维护相对简单得多。基于B/S结构的Web应用体系有如此多的优势,因此本网上考试系统的主体就采用这种B/S体系结构。2.4 ADO.NET对象模型 ADO.NET对象模型中有五个主要的组件,分别是Connection对象、Command对象、DataAdapter、DataSet以及DataReader。这些组件中负责建立联机和数据操作的部分我们称为数据操作组件(Managed Providers)分别由Connection对象、Command对象、Dat
24、aAdapter对象以及DataReader对象所组成。数据操作组件最主要是当作DataSet对象以及数据源之间的桥梁,负责将数据源中的数据取出后植入DataSet对象中,以及将数据存回数据源的工作。ADO.NET对象模型如图所示:图2-2 ADO.NET对象模型 Connection组件Connection对象主要是开启程序和数据库之间的连结。没有利用连结对象将数据库打开,是无法从数据库中取得数据的。这个物件在ADO.NET的最底层,我们可以自己产生这个对象,或是由其它的对象自动产生。Command组件Command对象主要可以用来对数据库发出一些指令,例如可以对数据库下达查询、新增、修改、
25、删除数据等指令,以及呼叫存在数据库中的预存程序等。这个对象是架构在Connection对象上,也就是Command对象是透过连结到数据源的Connection对象来下命令的。所以Connection连结到哪个数据库,Command对象的命令就下到哪里。DataAdapter组件DataAdapter对象主要是在数据源以及DataSet之间执行数据传输的工作,它可以透过Command对象下达命令后,并将取得的数据放入DataSet对象中。这个对象是架构在Command对象上,并提供了许多配合DataSet使用的功能。DataSet组件DataSet这个对象可以视为一个暂存区(Cache),可以把
26、从数据库中所查询到的数据保留起来,甚至可以将整个数据库显示出来。DataSet的能力不只是可以储存多个Table而已,还可以透过DataAdapter对象取得一些例如主键等的数据表结构,并可以记录数据表间的关联。DataSet对象可以说是ADO.NET中重量级的对象,这个对象架构在DataAdapter对象上,本身不具备和数据源沟通的能力,也就是说我们是将DataAdapter对象当做DataSet对象以及数据源间传输数据的桥梁。DataReader组件当我们只需要循序的读取数据而不需要其它操作时,可以使用DataReader对象。DataReader对象只是一次一笔向下循序的读取数据源中的数
27、据,而且这些数据是只读的,并不允许作其它的操作。因为DataReade在读取数据的时候限制了每次只读取一笔,而且只能只读,所以使用起来不但节省资源而且效率很好。使用DataReader对象除了效率较好之外,因为不用把数据全部传回,故可以降低网络的负载。2.5 系统数据库设计 2.5.1 数据库结构及说明 数据库结构是网上考试系统设计方案中的一个重要组成部分,目的在于满足考生、管理员用户实现其操作功能。数据库中表的设计:1)管理员信息表(admin),如图2-3:图2-3管理员信息表2)学生信息表结构(student) ,如图2-4:图2-4学生信息表结构3)试题信息表结构(question),
28、如图2-5:图2-5 试题信息表4)考试科目信息表结构(subject),如图2-6:图2-6考试科目信息5)考生成绩表结构(score),如图2-7所示:图2-7 考生成绩表2.5.2 用户权限简介 1) 管理员在此系统中系统管理员具有管理用户、管理试题和试卷的权力。他不需注册,在数据库有一个表来存放相关信息。2) 一般用户主要是指考生,参加在线考试。第三章 系统的整体分析与设计3.1 需求分析 3.1.1 系统需要解决的主要问题 考生进入系统应该进行身份验证。考生进入考试系统后,需要选择考试科目,所以系统还应有考试科目选择的功能。鉴于考试环境一般为机房,考试者之间的距离很近,为了避免考试做
29、弊,试卷的试题和题量都应是相同的,但试题并不相同。在线考试基于网络环境,试卷应该从服务器的数据库随机抽取试题后动态生成的。另外,系统还应该对考试时间进行控制,时间到了会要求考试者交卷。考试者选择提交答卷后,应该自动判卷,给出考生分数。本系统是为了满足在线考试的需求而设计开发的,可在Internet上进行实时考试。所以本考试系统应具备的考试系统功能,包括:题库设计和管理,试卷的随机组卷能力,用户在线考试及记录,系统自动评卷,系统数据库管理维护,系统管理和维护。3.1.2 系统功能模块划分 本在线考试系统可分为两个主要功能模块进行设计,这两个功能模块分别为:1)考生功能模块:考生功能模块可以实现考
30、生登录、选择考试科目、在线考试、完成考试给出分数,如果已经考过,则不能登录考试。2)管理员功能模块:管理员功能模块可以实现管理员登录、考生信息管理、考试科目管理、题库管理、考试成绩管理。系统统由一个登陆界面登陆,在登陆时是如果是学生,则用户名为考生学号,如果是管理员登陆,用户名为管理员名,分别从各自己的数据库中查询帐户,并核对登陆密码,然后根据不同的角色进入不同的界面。系统功能模块划分如图3-1所示:图3-1 系统功能模块划分图3.2 总体设计 本部分介绍了基于Web的网上考试系统的总体设计,主要包括公用登陆模块的设计,学生功能模块的设计,管理员功能模块的设计。程序总体流程图如图3-2所示:图
31、3-2 程序总体流程图3.2.1 公共登陆模块设计 所有用户都从本模块登陆,登陆界面(login/)上包括一个文本框用于输入用户名,一个文本框用于输入密码;包括两个按钮,用来区分考生登录,还是管理员登陆。点击登陆后,根据不同按钮的单击事件,连接到不同的数据库,从相应的数据库表中查询用户名和密码,如查询到,则进入相应的页面,如未查询到,则弹出出错信息,用户点击确定重新输入用户名和密码登陆,图3-3示: 图3-3 用户登录界面3.2.2 在线考试模块设计 考生登录后,进入考试须知页面(know1/),选择考试科目后,若未参加该科目的考试,则进入相应科目考试页面;否则,不能进入考试页面。该页面主要提
32、供了一个考生选择考试科目的功能,以简单的超链接进入不同的科目考试页面。考试须知页面如图3-4示:图3-4 考试须知页面3.2.3 管理员功能模块设计 管理员登录后进入后台管理主页面(classintro/),由该页面可以登录到学生信息管理、科目管理、试题管理、成绩管理页面。如图3-6所示:图3-6 后台管理主页面第四章 部分页面实现详解4.1 考试页面的实现 考试页面(exampage/)可以进行单选、多选、填空题这些客观题的考试。每一类型题都以一个Web用户控件来实现题目显示,试题是随机生成的,每次考试都不同的试卷,如图3-5所示:图3-5 考试页面系统以随机抽题来生成试卷,使用了一个随机函
33、数。先在题库question表中得到每种题型在每次抽题供抽取的总题数count= SubjectInfo(Subject),随机选题时应在1-count之间选取,temp = Fix(count * Rnd(10)。由于试卷是考前随机抽题而得,考生在第一时间开启试卷,减少了接触试题的人员间环节,也在一定程度上防止了考生将试题传出考场,增强了试题的保密性其次,为了避免由于得到的随机数相同,而在一份试卷中抽到相同的考题,在设计题库结构时设置了haveselect标记字段,标记字段取值为0时,该题未被抽取,haveselect标记字段取值为1,表示该题已被抽取,不能再用。这统在抽题时,首先判断hav
34、eselect标记字段是否为0,如果该题已被抽过,则必取新的随机数重新抽取。下面以单选题为例来说明。/将haveselect置为1,标记该题为已选Public Function SetReaded(ByVal QuestionID As String)strsql = update question set haveselect=1 Where id= & CInt(QuestionID) ExeSQL(strsql)End Function /将haveselect置为0,该课程所有的考题初始化Public Sub SetRead() strsql = update question set
35、 haveselect=0 where subjectname= & Subject & ExeSQL(strsql)End Sub/用随机函数Rnd()来生成试题号Public Sub DataBingToRep()strsql = select top & 1 & * from question Where subjectname= & Subject & AND type=单选题and haveselect= 0 Randomize()count = SubjectInfo(Subject)temp = Fix(count * Rnd(100)If Qds.Tables(0).Rows.
36、Count 0 Then GetRowInfo(Qds.Tables(0).Rows(temp)ElselblQesName.Text = 暂时没有 & Subject & 的单选题!End IfEnd Sub/统计课程考题的数量, 获得count值Function SubjectInfo(ByVal name As String) As Integer strsql = select * from question where subjectname= & name & AND type=单选题and haveselect=0 Dim cmd As New SqlDataAdapter(st
37、rsql, appconn) cmd.Fill(Qds, Info) Return Qds.Tables(Info).Rows.CountEnd Function4.2 管理主页面的实现 管理主页面是管理员进入后台管理后所看到的第一个页面,在该页面上有Label控件显示了管理员名,登录时间信息,一组超链接实现各个页面之间的跳转,以一个表格中加入超链接图片也可以在不同页面之间跳转,该页面主要是管理员欢迎界面,没有什么关键代码,只是超链接的使用。4.3 学生信息管理页面(manstudentinfo/)的实现 该页面用DataGrid控件显示了学生信息,并实现了分页显示,同时以下拉列表事件来实现按
38、班级查询学生信息,其中班级是从数据库里查询出来的不重复的班级,还以下拉列表提供了按序号、学号、姓名进行的关键字查询,以超链接实现了跳转到添加、修改学生信息页面。如图4-1所示:图4-1 学生信息管理页面关键代码解释:/定义数据库连接字符串,Dim conn As New SqlConnection(ConfigurationSettings.AppSettings(ConnectionString)/使用DISTINCT关键字搜索出数据库中的不同班级,class_name为下拉列表控件comdstr2 = select DISTINCT class from studentclass_name
39、.DataSource = studs.Tables(student1)class_name.DataBind()class_name.Items.Insert(0, New ListItem(全部, 全部)/使第一项显示为“全部”class_name.SelectedIndex = class_name.Items.IndexOf(class_name.Items.FindByText(全部)/使用Response.Redirect可以将网页转移至另外的网页上,使用的语法结构是:Response.Redirect网址,其中网址可以是相对地址或绝对地址,在此使用Response.Redirec
40、t(addstudentinfo/)跳转到修改学生信息页面Session(studentid) = s_datagrid.DataKeys(CInt(E.Item.ItemIndex) /使用下拉列表控件的SelectedIndexChanged事件,实现下拉列表改变,自动按不同班级查询学生信息Public Sub class_name_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles class_name.SelectedIndexChanged dblstr =
41、Request.Form(class_name) ifsub()End Sub/根据不同的查询条件生成不同的查询字符串Sub ifsub()/使用like % & key & %实现按关键字查询,以下输入学号关键字为来实现查询 If skey = s_no Then comdskey = where s_no like % & key & % comdstr = select * from student & comdskey End If Session(str) = comdstr adp = New SqlDataAdapter(comdstr, conn) ds = New DataS
42、et adp.Fill(ds, student) s_datagrid.DataSource = ds.Tables(student).DefaultView s_datagrid.DataBind()End Sub4.3.1 添加、修改学生信息(addstudentinfo/updatestudentifo) 添加学生信息与修改学生信息共用一个页面,在执行不同操作时,传递不同的参数editstudent,当editstudent为空值时,显示添加学生信息页面,不为空显示为修改学生信息,并根据参数绑定数据库中的对应的学生信息,显示在相应的文本框或下拉列表中。如图4-2所示:图4-2 添加、修改
43、学生信息页面关键代码解释:/根据不同editstudent参数值显示不同的页面标题,其中editstudent为学生id添加学生信息修改学生信息/根据不同editstudent参数值显示不同的按钮文本/该句的功能是把表单提交的变量editstudent的值赋给一个Session对象studentid。这个对象用来存储学生id,它在用户对每个页面的访问中有效。editstudent = Session(studentid)/点击修改学生信息事件,使用Request对象的Form获得页面上表单的内容 nums = Request.Form(num) names = Request.Form(nam
44、e) pwds = Request.Form(pwd) grades = Request.Form(grade)strA = update student set s_no= & nums & ,s_name= & names & ,s_pwd= & pwds & ,class= & grades & where id= & editstudent致谢 在本次论文设计过程中,陈翠红老师对该论文从选题,构思到最后定稿的各个环节给予细心指引与教导,使我得以最终完成毕业论文设计。在学习中,老师严谨的治学态度、丰富渊博的知识、敏锐的学术思维、精益求精的工作态度以及侮人不倦的师者风范是我终生学习的楷模,
45、导师们的高深精湛的造诣与严谨求实的治学精神,将永远激励着我。这三年中还得到众多老师的关心支持和帮助。在此,谨向老师们致以衷心的感谢和崇高的敬意!最后,我要向百忙之中抽时间对本文进行审阅,评议和参与本人论文答辩的各位老师表示感谢。参考文献1)李克东,谢幼如等编著多媒体组合教学设计M北京:科学出版社1992(1)。2)徐玲,吕磊等编著基于B/S结构的高校教务办公自动化的设计与实现J电脑信息技术2001 5(3) 18-19。3)明日科技,盖天宇,孙明丽,邹天思等编著ASP数据库系统开发案例精选M北京:人民邮电出版社2006:56-89。4)韩朝军,梁冰,刘莹等编著SQL Server管理与开发技术大全M北京:科学出版社.