《基于VB的在线考试系统(共37页).doc》由会员分享,可在线阅读,更多相关《基于VB的在线考试系统(共37页).doc(37页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上芜湖职业技术学院毕 业 论 文题 目:基于Visual Basic 的在线考试系统院系名称:信息工程系专业班级:09级计算机应用2班学生姓名:张勇 学 号:指导教师:陈万顺2011年11月15日摘 要随着网络的普及和对教育的重视,各院校各学科的网上考试都具有了必要的使用环境。但是,目前国内的一些网络教学系统的主要功能是教学,不能单独作为考试平台,通用性差,而且系统中对主观题的评阅多是采用人工评阅方式,没有实现真正意义上的自动评分。另一方面,我们所在院校的计算机基础课已开设了多年,但尚在沿用传统的考试形式或使用单机版的考试系统。网上考试系统的设计与实现就是基于上述目的开
2、发设计的。本系统采用C/S架构作为系统的总体结构,以数据库技术为依托,利用微软的ADO技术,实现了对数据库的访问和查询。该设计实现了随机抽题组卷、在线考试、题库管理。能够对客观题在线评分。学生用学号登录成功后,进入考试页面,完成考试后,自动给出考试成绩。网上考试系统本身是一个很大的系统,尤其试题库部分需要许多人的参与以及大量的投入才能建成。该系统虽然仅仅是完成计算机文化基础和操作系统课程的考试,但却具有良好的实用性与通用性,提供友好的人机界面,具有较好的可扩充性和开放性。关键词:在线考试,ADODC,Winscok目 次第一章 引 言1.1 开发背景网络技术的发展使得考试的技术手段和载体发生了
3、革命性的变化,网络的开放性、分布性的特点和基于计算机网络的巨大的计算能力使得考试突破了时间和空间的限制。与传统考试模式相比,在线考试具有无可比拟的优越性,它可以将传统考试过程中的试卷组织、审定印制、传送收集、登记发放、评判归档各个环节缩小到一至两个环节,减小了人工直接干预考试活动的可能性,不但能够节约大量的时日、人力、物力与财力,而且还可以大幅度增加考试成绩的客观性和公正性。 传统的考试方式一般要经过人工出卷、考生考试、人工阅卷等过程。对于一些课程来说,随着考生数量的增加,教师出卷阅卷的工作量将会越来越大,并且其工作十分烦琐和非常容易出错。在线考试系统课题产生的背景是当今教育信息化的趋势及我国
4、高校教育信息化系统的建设,目的是充分利用学校现有的计算机软、硬件和网络资源实现无纸化考试以避免传统手工考试的不足。与传统考试模式相比,网上考试渗入了更多的技术环节,对实现安全性的途径、方法也提出了更高的技术要求。通过网络来实现网上考试,是现代教育技术的一个具体实现,具有很重要的现实意义。可以实现教考分离以及考务工作的全自动化管理,可以有效利用校园网的软硬件资源,使其发挥最大效力,更好的为学校的教学、科研、管理服务,可以大规模的实行考试,实现考试的客观性、公证性,自动化组卷、阅卷可以减轻教师的工作强度。传统考试要求老师出试卷、印试卷、安排考试、监考、收集试卷、评改试卷、讲评试卷和分析试卷。这是一
5、个漫长而复杂的过程,已经越来越不适应现代教学的需要。在线考试系统是传统考场的延伸,它可以利用网络的无限广阔空间,随时随地的对学生进行考试,加上数据库技术的利用,大大简化了传统考试的过程。 本文以局域网网络为平台,研究了基于C/S架构考试系统的设计与开发,包括系统需求分析和系统功能设计以及数据库设计。重点阐述了用户登录模块、在线考试模块、试卷管理模块、用户管理模块、成绩管理模块的设计。 1.2 开发意义在网络技术逐渐渗入社会生活各个层面的今天,传统的考试方式也面临着变革,而网络考试则是一个很重要的方向。基于C/S技术的网络考试系统可以借助于遍布全球的网络平台进行,大大丰富了考试的灵活性。试卷可以
6、根据题库中的内容即时生成,可避免考试前的压题;而且可以采用大量标准化试题,从而使用计算机阅卷,大大提高阅卷效率;还可以直接把成绩送到数据库中。所以现在较好的考试方法为网络考试,试题内容放在服务器上,考生通过姓名、准考证号码进行登录,考试答案也存放在服务器中,这样考试的公平性、答案的安全性可以得到有效的保证。因此,采用网络考试方式将是以后考试发展的趋势。近几年来,借鉴发达国家的成功经验,结合我国的实际情况,伴随着网络应用的不断扩大,远程教育和虚拟大学的出现,网络应用正不断深入人心。人们迫切要求利用网络技术进行在线考试,来提高了考试的质量,突出公正和客观性,减轻组织及保障工作的负担,提高工作效率。
7、于是许多教育教学类的课程在线考试软件应运而生,高等学校,企事业单位也都纷纷组织研究此类应用的解决方案,并研制开发了大量的不同类型计算机在线考试软件,也推出了一批优秀的在线考试软件产品,比如全国计算机等级考试软件、职称计算机能力考试等等。有力的推动了我国网络化在线考试的发展水平,并积累了大量有价值的经验。第2章 系统开发工具及开发平台2.1 开发工具及平台本系统采用 VB 语言开发制作,用Visual Studio6.0和SQL SERVER 2000作为开发工具,用软件数据库理论设计数据库,SQL语言进行数据库查询、插入、删除等操作,设计出能实现各个功能模块的应用程序(C/S)模式。2.2 开
8、发工具的简单介绍2.2.1 Visual Basic 6.06.0 是由Microsoft公司推出的开发工具Visual Studio 6.0 套件中的一员、是近年来在国内外得到迅速推广应用的可视化,具有简单易学,功能强大,费用支出低,见效快等特点.它提供了开发Windows最迅速,最简捷的方法, 尤其适合Windows平台下的小型软件的开发与编写。VB6.0所提供的开发环境与Windows 9x,Windows NT4.0或Windows XP具有完全一致的界面,使用更方便,其代码效率已达到的水平.在方面,6.0版的VB全面支持,包括数据抽象,封装,对象与属性,类与成员,继承和等. 2.2.
9、2 SQL Server2000Microsoft SQL Server 2000是一个高性能的客户端/服务器结构的关系数据库管理系统(RDBMS,Relational Database Management System)。SQL Server 2000是为了支持高容量的事务处理以及数据仓库和决策支持系统(比如销售分析应用)而设计的。它运行在Microsoft Windows NT4或Microsoft Windows 2000 Server上-基于intel处理器的网络。可以把SQL Server 2000作为一种个人桌面数据库系统安装在运行Window NT Workstation 4、
10、Windows 2000 Professional、Windows98和Windows Millennium Edition(Me)的机器上。可以使用相同的CD来安装任何一个SQL Server 2000的服务器版本或个人版本。2.2.3 访问数据库:ADO在数据库程序设计方面,使用ADO作为数据库存取的接口。ADO采用新颖的对象观念,专为Microsoft.NET平台量身打造,采用离线存取模式,可供多人同时存取,特别适合在Internet环境中使用。ADO.NET是微软新一代.NET数据库的存取结构,ADO.NET是数据库和数据源间沟通的桥梁,主要提供一个面向对象的数据存取架构,用来开发数据
11、库应用程序。ADO.NET具有下列优越性:l ADO.NET 是在.NET Framework上存取数据库的一组类库,它包含了.NET Data Provider(数据提供者)以进行数据库的连接与存取,通过ADO.NET,数据库程序设计人员能够很轻松地使用各种对象,来存取符合自己需求的数据库内容。换句话说,ADO.NET定义了一个数据库存取的标准接口,让提供数据库管理系统的各个厂商可以根据此标准,开发相应的.NET Data Provider,如此编写数据库应用程序人员不必了解各类数据库底层运作的细节,只要学会ADO.NET提供对象的架构,便可轻易地存取所有支持. NET Data Provi
12、der的数据库。l ADO.NET是应用程序和数据源之间沟通的桥梁。通过ADO.NET提供的对象,再配合SQL语法就可以存取数据库内的数据,而且凡是通过ODBC或OLEDB接口所能存取的数据库(如:Dbase、FoxPro、Excel、Access、SQL Server、Oracle等),也可通过ADO.NET对象来存取。l ADO.NET可提高数据库的延展性。ADO.NET可以将数据库内的数据以XML格式传送到客户端(Client)的Dataset对象中,此时客户端可以和数据库服务器联机,当客户端程序对数据进行新增、修改、删除等动作后,再和数据库服务器联机,将数据送回数据库服务器端完成更新的
13、动作。如此一来就可以避免客户端和数据库服务器联机时,当客户端不对数据库服务器作任何动作时,却一直占用数据库服务器的资源。此种结构使得数据处理有相互连接的双层结构,朝多层结构发展,因而提高了数据库的延展性。2.2.4 网络通信 WinsockWinsock是Windows下网络变成的规范,是由Microsoft公司在BSD UNIX中流行的Socket接口为范例定义了一套Microsoft Windows下网络编程接口。它不仅包含了人们所熟悉的Berkeley Socket风格的库函数;也包含了一组针对Windows的扩展库函数,以使程序员能充分地利用Windows进行编程。使用Winsock的
14、软件研发人员不需要了解网络知识,也不需要关心数据在网络上传送过程。需要的仅仅是初始化网络的通信方式和协议,通过Winsock提供的一系列属性方法即可完成高效率的网络数据传输。方便了软件开发的周期和难度。本系统选用了SQL 数据库,它具有简单易学,操作方便的特性。如果需要,还可以稍加修改,将数据库与应用程序分离,采用客户端/服务器方式,将数据库放置到服务器端,此软件作为客户端应用程序,可对数据库进行联机存取。第3章 系统分析3.1 系统及需求分析3.1.1 系统需求通过调查,要求系统需要有以下功能:(1) 考试模块:考试在登录界面内选择不同的准考证号实现考生信息的识别,从服务器上获取试卷信息,完
15、成答卷并提交试卷.(2) 管理模块:可以维护学生的个人信息。可以增加,删除,修改试题及查看学生的成绩信息.能够抽取试题并发送试卷到客户端,对客户端发送的试卷答案评分并记录3.1.2 可行性分析可行性分析是在系统调查的基础上,针对新系统的开发是否具有必要性和可行性,对新系统的开发从技术、经济、社会的方面进行可行性分析和研究,以避免投资失误,保证新系统的开发成功。可行性分析的目的就是用最小的代价在尽可能短的时间内确定问题是否能解决。该系统的可行性分析包括如下几个内容:(1)技术方面的可行性:它主要分析技术条件是否顺利完成开发工作,软硬件是否满足开发者的需要等。其中,软件方面在线考试需要的软件环境都
16、已具备,数据库服务器方面则有SQL Server 2000,够处理大量数据,同时保持数据的完整性并提供许多高级管理功能,其灵活性、安全性、易用性为数据库编程提供了良好的条件。 (2) 经济方面的可行性:主要是对这项经济效益进行评价,本系统作为一个实验性的项目,无需开发经费并且这系统实施后可以显著提高考试效率,有助于学院实行网络管理化。(3) 操作方面的可行性:目前,大学校园网络覆盖了教学区和学生区的主要建筑物,从而满足各学院、各职能部门、各直属单位上网要求,学校良好的网络设施为开发使用无纸化考试网络系统提供了坚实基础。综上所述,此系统开发目标已经明确,在经济和技术等方面可行,并且投入少见效快。
17、3.2 系统功能简介服务器端部3.2.1 考号管理模块考号理模块包括查看信息、更改信息、删除信息等操作。如图3-1所示。考号管理查询信息修改/删除查看成绩图3-1 考号管理3.22 题库管理部分题库管理包括选择题管理,判断题管理。通过题库管理对各种类型的试题进行添加、删除、修改以及查询.各种类型试题的管理功能均类似,主要的操作有:添加试题、删除试题、修改试题和查看试题。如图3.2所示。 题库管理选择题管理判断题管理添加删除修改添加删除修改图3-2 题库管理3.2.3 服务管理服务管理主要是提供考试环境,包括:试题抽取,试卷发放,客户端监测以及对提交的试卷答案评分操作等。是整个考试系统的核心。客
18、户端部分3.2.4 系统登录部分考生输入自己的准考证号,发送给服务器。服务器端检查是否存在该考号及考试状态。然后决定是否进入考试界面.3.2.5 考试界面模块主要由题目显示部分。答题部分和答案显示部分。主要接收并显示从服务器上发送过来的题目。填入答案。提交给服务器评分。第4章 系统总体设计4.1 系统架构设计本系统采用VB应用程序的典型系统架构模式:数据库数据访问接口业务逻辑层。数据库是应用系统的基础,它保存系统中所有数据。数据接口层封装对数据库的操作,如创建数据库连接、打开数据库连接、执行存储过程和关闭数据库连接等。在本系统中,各个窗口(Form)通过数据接口层对数据库进行操作。整个系统架构
19、如图4-1所示窗口用户层数据接口层数据驱动层数据库图4-1系统架构4.2 系统功能模块划分从前面章节可以看出,本系统实现了完整的在线考试功能,可以根据这些功能设计出系统中的功能、模块。系统中的各个模块划分如图4.2所示:在线考试系统服务器部分客户端部分考号管理题库管理考试管理评分系统登录系统考试系统答案记录 图4-2 系统总体模块设计第5章数据库设计5.1 总体设计考虑到在线考试系统的实际需要,本系统需要的数据至少包括不同学生考号数据以及选择题数据、判断题数据等。不同考生的用户数据主要包括考生准考证号,考生名名,成绩,是否考试等数据;试题数据主要包括试题号、试题题目、试题选项、参考答案等数据.
20、5.2 表设计5.2.1 准考证号表KS_USER_NUMBERKS_USER_NUMBER表包括学生信息数据,如准考证号、姓名、考试情况、考试成绩。表的字段说明如表5.1所示。5-1 准考证号表5.2.2 选择题数据表KS_XZTKS_XZT包括选择题的信息,如题号、题目、选项、答案等,表的字段说明如表5-2所示 表5-2 选择题数据表5.2.3 判断题数据表KS_PDTKS_PDT包括判断题的信息,同KS_XZT表一样,包含了题号、选项、答案等.表的字段说明如表5-3所示表5-3 判断题数据表第6章 系统功能详细设计及实现6.1 数据库驱动连接部分数据库连接和驱动利用的是微软提供的DSN数
21、据源接口,数据源选择如图6-1所示,连接属性如图6-2。利用Microsoft addoc 控件连接并操作数据源,部分代码片段如下:Public mydb As ADODB.Connection 声明ADO.Connection公共对象Public re As ADODB.Recordset 声明ADO.Recordst公共对象Public gd As ADODB.RecordsetPublic cmd As ADODB.Command 声明ADO.Command公共对象Public tmp As ADODB.RecordsetPublic PCname As String 本机名Dim DB
22、name As String 数据库名Dim DBSQLTEXT As String 连接字符串PCname = YONG-PCDBname = KSRJDBSQLTEXT = Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog= & DBname & ;Data Source= & PCnameSet mydb = New ADODB.Connection 创建ADODB.Connection实例Set re = New ADODB.Recordset 创建ADODB
23、.Recordset实例Set cmd = New ADODB.Command 创建ADODB.Command实例mydb.ConnectionString = DBSQLTEXT 设定连接参数mydb.Open打开数据库cmd.ActiveConnection = mydb绑定ADODB.Command对象re.CursorLocation = adUseClient连接模式为客户端模式re.CursorType = adOpenStatic静态游标re.LockType = adLockBatchOptimistic乐观锁定通过上述代码,数据库可成功被连接。同时数据表已记录集的 形式存储在
24、“re”数据对象实例中。软件调用数据表即可从re中直接提取。图6-1 数据源选择图6-2 选择数据库6.2试题抽取试题抽取要做到随机、公平、公正因此不能采取人工干预的方式,需用系统随机抽取。这一部分的设计主要思想是先生成一个长度为所需题目数的随机数组,数组中的每个数在1到题库中最大的题目数之间而且不能重复,利用这个随机数组来选择抽取的题目。对于随机数的产生。由于Rnd()函数生成的是伪随机数。无法满足要求,这里采用毫秒级的时间作为种子,对记录集里最大题号求余.先利用Timer()去得系统当前时间,取出其中毫秒时间。求余后存入随机数数组。代码片段如下Dim ct As Integer Dim r
25、nd_pt As IntegerDim send_str As String试题缓冲区Dim rnd_tmp As Integer存取随机变量值Dim rnd_tmp_pt As Integer 存放随机数数组rnd_tmp_pt = 1 数组指针rnd_pt = 1选择题抽取Do用毫秒除以最大记录数Lop: rnd_tmp = Timer() * 1000 Mod re.RecordCountDo去重复If rnd_tmp = rnd_arry(rnd_tmp_pt) ThenGoTo LopEnd Ifrnd_tmp_pt = rnd_tmp_pt + 1Loop Until rnd_tm
26、p_pt rnd_ptrnd_tmp_pt = 1rnd_arry(rnd_pt) = rnd_tmp 存入数组rnd_pt = rnd_pt + 1Loop Until rnd_pt 30rnd_pt = 1rnd_tmp_pt = 1判断题抽取DoLop2: rnd_tmp = Timer() * 1000 Mod re.RecordCountDoIf rnd_tmp = rnd_pdt_arry(rnd_tmp_pt) ThenGoTo Lop2End Ifrnd_tmp_pt = rnd_tmp_pt + 1Loop Until rnd_tmp_pt rnd_ptrnd_tmp_pt
27、= 1rnd_pdt_arry(rnd_pt) = rnd_tmprnd_pt = rnd_pt + 1Loop Until rnd_pt 206.3 网络通信网络通信部分采用Winsock通用控件。采用TCP传输模式,保证了数据的可靠正确的传输。本地端口和远程端口均由程序运行是代码指定Winsock控件的属性设置如图6-3图6-3 Winsock控件属性设置Winsock的传输模式为“透明传输”。即它支付负责OSI参考协议中传输层及其以下层的协议,没有设计到表示层及会话层。因为软件中需采用协议来标识所传输的数据的类型。本程序采用的是“包头标识”的方法来标识所传输的数据的类型。将每次传输的数据
28、串前端打上5个二进制标志位。利用这些标志位来区分数据类型。表6-1 数据串标志头表(部分)头标志字符串数据类型00010发送准考证号信息00011准考证号回应信息00111无考证号时回应信息数据的传输只需调用Winsock控件的send方法。收到数据时触发DataArrival事件.每次发送数据前需检查控件的连接状态。PCname = YONG-PC 设置服务器名称PCip = net.LocalIP 获取服务器本地IPnet_pt = 1 发送缓冲区指针net.LocalPort = 2013 本地端口net.Listen 侦听端口Private Sub net_Close() 当连接关闭时
29、重新打开并侦听连接If net.State sckClosed Then net.Closenet.ListenEnd SubPrivate Sub net_ConnectionRequest(ByVal requestID As Long)If net.State sckClosed Then net.Closenet.Accept requestID 有连接请求是运行连接End SubPrivate Sub net_DataArrival(ByVal bytesTotal As Long)Dim i As Integeri = 1cj = 0net.GetData net_buff有数据到
30、达时先存入缓冲区Dim acc_str As Stringacc_str = Mid(net_buff, 6, 8) 读取数据串标志头6.4 评分模块评分系统由电脑全自动完成,首先读取客户端发送过来的答题信息,再与从数据集里面取出来的答案相比较,答案正确则总分加4分(选择题)或2分(判断题)。评分完毕存入准考证号数据表KS_USER_NUMBER。评分部分代码如下If Mid(net_buff, 1, 5) = 11111 Then 如果标志头为“11111”Do 则为答题信息数据串If Mid(net_buff, 5 + i, 1) = xzt_da_arry(i) Thencj = cj
31、+ 4选择题答案正确则加分End Ifi = i + 1Loop Until i 20i = 1DoIf Mid(net_buff, 25 + i, 1) = pdt_da_arry(i) Thencj = cj + 2End Ifi = i + 2Loop Until i 10cmd.CommandText = UPDATE KS_USER_NUMBER SET 已考试 = 1 , 成绩 = & cj & WHERE 准考证号 = & xhIf re.State adStateClosed Then re.Closere.Open cmdaj = MsgBox(评分完成,单击结束退出系统,
32、vbOKOnly + 32, 提示)end if第七章 系统界面总览7.1 服务器端图7-1 服务端主界面图7-2 考号管理界面图7-3 选择题题库管理7-4 判断题题库管理7-5 考试服务界面7.2 客户端部分图7-6 登录界面图 7-7 阅卷答题界面总 结一个完备的在线考试系统可以使用户在学习过后及时检验自己的学习效果,以发现自己的不足,使得学习效率得到很大提高。在线考试系统中题目的生成、试卷的提交、成绩的批阅等都可以在网络上自动完成。只要形成一套成熟的题库就可以实现考试的自动化。这样一来,教师所要做的只是精心设计题目、维护题库,而不是组织考试,从而大大减轻了教师的负担,这表明其经济性是相
33、当可观的。为了适应新形势的发展,作者进行了一次在线考试系统的探索。并且在本文中详细论述了在线考试系统的设计与实现,该系统基本实现了需求分析中的功能要求,其中考生信息可以直接输入得来,考生成功登录后进入考试界面,考完后对考试题自动评分、存档。本系统还有许多方面尚未完善。系统对操作人员录入的错误数据和数据本身的错误所造成数据的 不完整性,系统的约束力较弱,在系统的更进一步的实现阶段,应加强数据的完整性约束提高系统数据的正确性和相容性,以及系统的容错性,加强对用户输入端的数据进行检验。另外,本系统只提供了一些基本的查询与删除、修改功能。这些功能还不能完全满足大家的需求。为了揭求教学过程的全貌,还需要
34、进一步地引入新的测量指标,并详细阐述它在教育中所代表的含义,如知识点的掌握度、频数分布图等等,为了给没有教育测量背景的教师和学生参考,还将制作测量指标的应用案例,说明如何在实际教学过程中应用这些指标。致 谢通过这段时间的毕业设计,使我对软件开发有了更深一层的了解。经过这些天的编程与不断调试,我们的努力终于有了成果。在这次的毕业设计中,我们理论与实际结合,获取需求分析结果,对后期的软件设计有一定的帮助作用。在数据库设计阶段,由于考虑问题不周到,所以到后期的软件调试时,发现设计出错,需要重新设计。所以,下次的软件设计,就可以借鉴这次的经验,对我也有一定的帮助作用。这次我受益匪浅。给我以后的路也有一
35、定的指导作用。在此向所有在此次毕业设计中给予我们关心、支持和帮助的老师、朋友们致以最诚挚的谢意!在整个设计过程中,很多老师、同学给了我们莫大的帮助。不能忘记,在我遇到重重困难时指导老师的谆谆教导;不能忘记,许多同学给予我们的支持和无私的帮助。我对大家的感谢之情难以言表。我深知,只有不断的拼搏进取,不断的前进,才是对大家最好的感谢。向我们尊敬的指导教师陈万顺老师致谢!感谢陈老师在设计过程中不厌其烦的关心我们、指导并且给了我们一些实质性的建议和意见,以及对设计小组全体成员的关心和教诲。非常感谢陈老师的教导,这才使的我们的软件功能更强大,界面更加友好,操作更加简捷、容易。同时还要向给予我们大力协助的同学致谢!最后,感谢各位评阅论文以及参加论文答辩的老师!参 考 文 献1.冯建华 周立柱 郝小龙编著. 数据库系统设计与原理.第2版.清华大学出版社,2007.6:163-205页 2.赛奎春主编.ASP工程应用于项目实践. 修订版.机械工业出版社,2005.9:97-135页3.林邦杰. 程序设计入门教程. 第三版. 北京:清华大学出版社,2004.3:162-229页专心-专注-专业
限制150内