1、计算机实验室教学管理系统的设计与实现 摘 要 随着计算机应用比例逐年增多,实现计算机实验室教学管理自动化也变得越来越必要,它既可以方便老师管理学生的基本数据,也可以使学生在上机的时候能够在线提交实验报告,上机后对实验结果进行保存。 该毕业设计采用 B/S 模式开发,采用 ASP 实现前后台的数据交互, SQL Sever 2000 作为数据库服务器。该系统实现了计算机实验室教学管理的自动化,系统分为管理员(老师)和学生两种权限,主要实现了实验环境的配置、学生信息的管理、老师信息的管理、班级的管理、实验报告的管理等功能 。学生可以利用此系统修改上机的密码、做实验、提交实验报告;管理员(老师)可以
2、通过该系统查看学生的实验报告,设置班级、老师、学生的基本信息等。 关键词 : ASP; SQL Sever;教学管理 The Design and Implementation of Computer Laboratory Teaching Management System Abstract With continuously development of computer application, automation of computer lab management becomes more and more necessary, which can not only conveni
3、ence teacher in managing basic data of student ,but also convenience student in submitting experiment report online and saving experiment result. This system is based on B/S mode. ASP dynamic web technology is used as its main development language to achieve data interactivity between foreground and
4、 background. SQL Server 2000 is used as a database server in background. The computer lab management system implements automatism of computer lab management, which has two authorizations-manager and student. The main functions of the system are experiment environment deployment, , student informatio
5、n management, teacher information management, class management and experiment report management. Students can update password, do experiment and submit experiment reports in this system, teachers can query experiment report, set information of class, teacher, student. and so on. . Key words: ASP; SQ
6、L server 2000; teaching management 第 1 页 1 引言 1.1 课题背 景 随着计算机信息技术的发展,计算机在教育领域应用日趋广泛。计算机上机的比例逐年增多;为了计算机实验室的管理更加方便,也使学生在上机的时候能够更灵活的处理所遇到的问题,上机后学生的上机的结果的保存与收集都是需要考虑的问题。本毕业设计利用 internet 技术,开发一个计算机实验室的教学管理系统。 1.2 本课题研究的意义 随着计算机信息技术的发展,计算机在教育领域应用日趋广泛。计算机上机的比例逐年增多;为了计算机实验室的管理更加方便,也使学生在上机的时候能够更灵活的处理所遇到的问题,上
7、机后学生的上机的结果的保存与收 集都是需要考虑的问题。本毕业设计利用 internet 技术,开发一个计算机实验室的教学管理系统。老师可以利用此系统配置实验环境,管理班级、老师、学生的基本信息,查看学生的实验报告,收集学生上机实验结果。学生可以利用此系统,缴交作业、交流学习心得等。要求能够为每门课程、每个老师提供比较完善的解决方案 .通过本系统的设计和开发不仅可以 考查我综合运用以前所学知识的能力,同时也使我了解了当今网编程的一些新技术;锻炼了我的实际动手能力,对于我以后工作能力的培养具有重要的意义 1.3 本课题研究的方法 本次毕业设计应首先分析 计算 机实验室教学管理系统 的相关功能,结合
8、本次毕业设计的相关要求写出需求分析;其次,综合运用以前所学的相关知识,选择 ASP+ SQL Server 进行本毕业设计的开发;在设计中以需求分析为基础,写出系统开发计划、实现流程及相关问题的实现方法;同时,在开发设计与实现中,保存好相关的设计文挡,为后面的毕业论文的写作准备材料;最后,系统开发完毕后,进行调试和试运行,做好调试和试运行的相关记录,也为后面的毕业论文的写作准备材料。其中, 计算机实验室教学管理系统 是典型的信息管理系统,该系统的开发主要包括后台数据库的建立 .维 护和前端应用程序的开发三个方面。对于前者要求建立数据一致性和完整性强,前台应用程序系统要求应用程序功能完备, 易于
9、使用和界面友好等等。 2 开发语言及平台简介 2.1 开发语言 2.1.1 ASP 简介 Microsoft Active Server Pages 即我们所称的 ASP, 其实是一套 微软开发第 2 页 的服务器 端脚本环境, ASP 内含于 IIS 3.0 和 4.0 中 ,通过 ASP 我们可以结合 HTML网页、 ASP 指令和 ActiveX 元件建立动态 、 交互且高效的 WEB 服务器应用程序。在 ASP 中 必担心所有的程序都将在服务器端执行 , 包括所有嵌在普通 HTML 中的脚本程序。当程序执行完毕后,服务器仅将执行的结果返回给客户浏览器,这样也就减轻了客户端浏览器的负担,
10、大大提高了交互的速度。 当浏览器浏览 ASP 网页时 , Web 服务器就会根据请求生成相应的 HTML 代码然后再返回给浏览器,这样浏览器端看到的就是动态生成的网页内容。 通过 ASP 可以结合 HTML 网页。 ASP指令建立动态、交互且高效的 WEB 服务器应用程序。 ASP 本身并不是一种脚本语言,它只是提供了一种使镶嵌在 HTML 页面中的脚本程序得以运行的环境。 ASP程序其实是以扩展名为 . 使用 VBScript、 Jscript 等简单易懂的脚本语言,结合 HTML 代码,即可快速地完成网站的应用程序。 1. 无须使用 compile 编辑,容易编写,可在服务器端执行。 2.
11、 使用普通的文本编辑器 , 如 Windows 的记事本,即可进行编辑设计。 3. 与浏览器无关 ( Browser Independence) ,用户端只要使用可执行 HTML 码的浏览器,即可浏览 Active Server Pages 所设计的网页内容。 Active Server Pages 所使用的脚本语言 (VBScript、 Jscript)均在 WEB 服务器端执行,用户端的浏览器不需 要能够执行这些脚本语言。 4. Active Server Pages 能与任何 ActiveX scripting 语言相容。除了可使用 VBScript 或 JScript 语言来设计外,还
12、通过 plug-in 的方式,使用由第三方所提供的其他脚本语言 , 譬如 REXX、 Perl、 Tcl 等。脚本引擎是处理脚本程序的 COM(Component Object Model) 物件。 5. Active Server Pages 的源程序,不会被传到客户浏览器,因而可以避免所写的源程序被他人剽窃也提高了程序的安全性。 6. 可使用 服务器端的脚本来产生客户端的脚本。 7. 物件导向( Object-oriented)。 8. ActiveX Server Components(ActiveX 服务器元件 )具有无限可扩充性。可以使用 Visual Basic、 Java、 Vi
13、sual C+、 COBOL 等编程语言来编写你所需要的 ActiveX Server Component。 ASP( Active Server Pages) 提供五个内置的 “ 对象 ”(object) ,可直接调用 。 1. Request:取得用户信息。 2. Response:传送信息给用户。 3. Server:提供访问服务器的方法 (methods)和属性 (properties)的功能。 第 3 页 4. Application:一个应用程序,可以在多个主页之间保留和使用一些共同 5. Session:一个用户 .可以在多个主页之间保留和使用一写共同的信息 .在多个主页之间共享
14、信息 . ASP 开发的应用程序 ,可以在多个主页之间保留和使用一些共同的信息 ,ASP提供两种使用范围 ,如下 : 1. Application: Applicationd 的所有信息 ,在一个应用程序 ,多个主页之间 ,可以让所有用户共同使用。 2. Session:Session 的所有信 息,仅适用于一个用户。 2.1.2 SQL server 2000 语言简介 SQL Server 是 “ 结构化查询语言 (Structured Query Language)的简称。 SQL是用户操作关系数据库的通用语言 ,SQL虽然叫结构化查询语言 ,其查询操作确实是数据库中的主要操作 ,包含数
15、据定义、数据操纵和数据控制等与数据库有关的全部功能。 SQL 语言是 1974 年由 Boyce 和 Chamberlin 提出的。 SQL Server 语言的特点: SQLserver 之所以能被用户和业界所接受并成为国际标准,是因为它是一个综合的,功能强大且又简洁易学的语言,其主要特点有: ( 1) 一体化; ( 2) 高度非过程化; ( 3) 语言简洁; ( 4) 有多种方式使用。 SQL Server 语言的组成可分为以下几部分: ( 1) 数据定义语言( Data Definition language):实现定义、删除和修改数据库对象的功能。 ( 2) 数据查询语言( Date
16、Query language):实现查询数据的功能。 ( 3) 数据操纵语言( Date Manipulation language):实现 对数据库数据的增加、删除和修改功能。 ( 4) 数据控制语言( Date Control language):实现控制用户对数据库的操作权限的功能。 SQL Server 允许用户在高层数据结构上工作 , 是一种用于数据库查询和编程的语言,已经成为关系型数据库普遍使用的标准,使用这种标准数据库语言对程序设计和数据库的维护都带来了极大的方便,广泛地应用于各种数据查询。 数据库,顾名思义,是存入数据的仓库。只 是 这个仓库是 建立 在计算机存储设备上的,而且
17、数据是按一定格式存放的。长期储存在计算机内的、有组织的、可共享的数据集合 是数据库 的一个简单定义 。数据库管理是有关建立、存储、修改和存取数据库中信息的技术,是指为保证数据库系统的正常运行和服务质量,第 4 页 有关人员须进行的技术管理。管理的主要内容有:数据库的建立、数据库的调整、数据库的重组、数据库的重构、数据库的安全控制、数据的完整性控制和对用户提供技术支持。 介于 SQL Server 一系列以上的优点,所以在开发本系统时采用 SQL Server2000,作为数据库工具。 2.1.3 Javascript 简介 JavaScript 是一种基于对象 (Object)和事件驱动 (E
18、vent Driven)并具有安全性能的脚本语言。使用它的目的是与 HTML 超文本标记语言、 Java 脚本语言( Java小程序)一起实现在一个 Web 页面中链接多个对象,与 Web 客户交互作用。从而可以开发客户端的应用程序等。它是通过嵌入或调入在标准的 HTML 语言中实现的。它的出现弥补了 HTML 语言的缺陷,它是 Java 与 HTML 折衷的选择 。JavaScript 是一种新的描述语言,它可以被 嵌 入到 HTML 的文件之 中。 JavaScript语言可以做到回应使用者的需求事件 , 而不用任何的网路来回传输资料,所以当一位使用者输入一项资料时,它不用经过传给伺 服端
19、 (server)处理,再传回来的过程,而直接可以被客户端 (client) 的应用程式所处理。 2.2 B/S 模式简介 B/S( Browser/Server,浏览器 /服务器)模式又称 B/S 结构。它是随着Internet 技术的兴起,对 C/S 模式应用的扩展。在这种结构下,用户工作界面是通过 IE 浏览器来实现的。在这种结构下,用户工作界面是通过 WWW 浏览器来实现,极少部分事务逻辑在前端( Browser)实现,但是主要事务逻辑在服务器端( Server)实现,形成所谓三层 3-tier 结构。这样就大大简化了客户端电脑载荷, 减轻了系统维护与升级的成本和工作量,降低了用户的总
20、体成本( TCO) 。以目前的技术看,局域网建立 B/S 结构的网络应用,并通过 Internet/Intranet模式下数据库应用,相对易于把握、成本也是较低的。 B/S 模式最大的好处是运行维护比较简便,能实现不同的人员,从不同的地点,以不同的接入方式(比如LAN, WAN, Internet/Intranet 等)访问和操作共同的数据 . 3 系统功能模块设计 3.1 系统概述 老师可以利用此系统配置实验环境、管理班级、老师、学生的进本信息、查看学生的实验报告;学生可以通过该系统做 实验,提交实验报告等。 3.2 主要功能模块 本系统根据学生和管理员两种身份划分了 3大模块:系统菜单、常
21、规设置、用户管理。如图 3.1 所示。 第 5 页 图 3.1 系统 功能模块图 其中学生可以操作的模块有各模块如下: 系统主页、登录密码设置、我的实验报告 /添加报告。 管理员可以操作的模块有: 系统主页、登录密码设置 、实验报告管理、班级设置、职务设置、软件路径设置、学生管理 /学生添加、教师管理 /教师添加、系统帐号管理 。 1. 系统菜单管理: 1) 实验报告的管理:管理员(老师)可以搜索、查看学 生的实验报告; 2) 登录密码设置:修改自己的登录密码。 2. 常规设置管理: 1) 班级设置管理:对班级的添加和删除已经不存在或者不需要使用该系统的班级; 2) 职务设置:对任课老师的添加
22、或者删除; 3) 软件路径设置:对学生进行实验所需的软件环境进行配置。 3. 用户菜单: 1) 学生信息管理:对新进的学生名单进行添加,对已经离校或者不需要再上机的学生名单进行删除; 2) 教师信息管理:对新的老师的添加,对已经离校的老师或者已经不再进行授课的老师的删除; 3) 系统管理员管理:对系统管理员帐号的设置和修改。 计算机实验室教学管理系统 系统菜单 常规设置 用户管理 系统帐号管理 教师管理/教师添加 学生管理/学生添加 软件路径设置 职务设置 班级设置 登录密码设置 实验报告管理 我的报告/添加报告 系统主页 第 6 页 3.3 数据库结构设计 该系统的数据库中主要包括四张表,
23、分别是 SQL 系统环境信息表( system),老师编号已及姓名信息表( class),实验报告信息表( articla),测试的老师已及学生信息表( user)。功能如表 4.1 所示。 表 3.1 数据库表介绍 数据表 描述 system SQL系统环境信息表 class 老师编号已及姓名信息表 articla 实验报告信息表 user 测试的老师已及学生信息表 1. 系统环境信息表 system 系统环境信息表用于存放用户的帐号等信息。包括软件编号( id)、软件图片( photo)、软件路径( filedepth)、用户 类型( title)、其中 ID 作为主关键字,该表结构如下表
24、所示。 表 3.2 系统环境信息表 字段名 数据类型及长度 说明 备注 id Int( 4) 软件编号 主关键字 photo Char( 50) 软件图片 Not null filedepth Char( 100) 软件路径 not null title Int( 4) 软件类型 not null 2. 老师、班级信息表 class 该表存放了用户的详细信息。包括老师、班级编号( ID)、用户类型( channleID)、用户名称( title)老师班级详细编号 ( orderID)其中,用户编号( id)为主关键字。该表结构如下表所示。 表 3.3 老师、班级信息表 class 字段名 数据
25、类型及长度 说明 备注 id Int( 4) 班级、老师编号 主关键字 ChannleID Int( 4) 用户类型名 No null title Char( 50) 用户名称 No null orderID Int( 4) 老师、班级详细编号 No null 3. 实验报告信息表 Article 该表存放了实验报告的各个信息。包括实验报告编号( ID)、实验报告名( title)、实验 报告内容( content)、实验报告者的姓名( author)、实验报告第 7 页 者的编号( userID) 学号( usernumber)、真实姓名( turename)实验报告提交时间 (update
26、time)。其中实验报告编号是主关键字,该表结构如下表所示。 表 3.4 实验报告信息表 Article 字段名 数据类型及长度 说明 备注 id Int( 4) 实验报告编号 主关键字 title Char( 500) 实验报告名 No null content Char( 6000) 实验报告内容 No null author Char( 500) 实验报告者的姓名 No null userID Int(4) 实验报告者的编号 No null Usernumber Int(6) 学号 No null Turename Char(500) 真实姓名 No null Updatetime Ch
27、ar(10) 提交时间 No null 4. 测试的老师已及学生信息表 user 该表介绍了该系统的所有测试用户信息。包括测试编号( id)、用户类型( usertype) 、测试的人员类型 (usernumber)、登陆密码 (password)、真实姓名 (turename)、性别 (sex)、测试者所在班级或老师类型 (classes)、测试时间 (prevtime),其中职位编号( id)为主关键字。该表结构如下表所示。 表 3.5 测试的老师已及学生信息表 字段名 数据类型及长度 说明 备注 id Int( 4) 编号 主关键字 usertype int( 4) 职位名 No nul
28、l Usernumber Char(10) 测试人员类型 No null Password Char(50) 登陆密码 No null Turename Char(500) 真 实姓名 No null Sex Char(500) 性别 Null classes Char(500) 测试者所在的班级或者老师类型 null prevtime Char(10) 测试时间 null 3.4 计算机实验室教学管理系统的设计与实现 3.4.1 登陆界面 登陆界面是用于老师和学生登录计算机实验室教学管理系统的界面,其风格如图所示: 第 8 页 图 3.2 系统登录界面 当用户登陆的时候, 首先用户填写登陆信
29、息表单,然后通过 myflag.asp 取得用户填写的信息并连接数 据库表 user 中的 password 和 usernumber 来验证用户是否合法。如果合法就进入计算机实验室管理系统的主界面 admin_left.asp,如果不合法系统则会提示输入合法的用户名和密码。 系统登陆界面的主要代码如下: Set rs=Server.CreateObject(“Adodb.Recordset“) rs.open “Select * From R_User where UserNumber=“&UserNumber&“ and Password=“&Password&“,conn,1,3 /数据
30、库的查询 验证用户登录的合法性 IF not(rs.bof and rs.eof) Then IF Password=rs(“Password“) Then rs(“Login“)=rs(“Login“)+1 /如果登录的密码和用户名正确就进入下一个连接 rs(“PrevTime“)=rs(“Lastlogin“) /上次登录的时间 rs(“PrevIP“)=rs(“LoginIP“) /上次登录的 IP rs(“Lastlogin“)=Now() rs(“LoginIP“)=CFUserIP() rs.update Session(“ID“)=rs(“ID“) /调用 session 对象,
31、存储用户 Session(“UserType“)=rs(“UserType“) /调用 session 对象,存储用户类型 Session(“UserNumber“)=rs(“UserNumber“) /调用 session 对象,存储用户帐号或者学号 Session(“TrueName“)=rs(“TrueName“) /调用 session 对象,存储用户的真实姓名 Session(“PrevTime“)=year(rs(“PrevTime“)&“-“&month(rs(“PrevTime“)&“-“&day(rs(“PrevTime“) /调用 session 对象,存储用户上次登陆的时间 Session(“PrevIP“)=rs(“PrevIP“) /调用 session 对象,存储用户上次登陆的 IP Session.Timeout=100 End IF rs.close Set rs=nothing conn.close Set conn=nothing /关闭数据库连接,释放内存