《毕业设计论文基于B/S的成绩管理系统.doc》由会员分享,可在线阅读,更多相关《毕业设计论文基于B/S的成绩管理系统.doc(52页珍藏版)》请在三一办公上搜索。
1、基于B/S的成绩管理系统目录第一章 引 言1第二章 可行性分析12.1 技术可行性分析12.2 经济可行性分析12.3 操作可行性分析1第三章 开发环境及工具13.1 开发环境13.2 开发工具2第四章 系统流程与规划24.1 系统目标规划24.2 系统流程图34.3 库结构设计34.3.1 用户表USER34.3.2 学生登记表STUDENT34.3 学期表TERM44.4 班级表CLASS44.5 成绩表CJB4第五章 系统的实现55.1 关键技术55.1.1 ASP技术55.1.2 ADO技术75.1.3 SQL Server数据库85.1.4 VBScript及JavaScript脚本
2、语言95.2 实现方法105.2.1 数据库连接方式105.2.2 用IIS配置Web服务器115.3 界面设计125.3.1 登录界面。125.3.2 学期管理界面125.3.3 成绩修改、添加界面135.3.4 批量添加成绩界面135.3.5 年级变迁界面145.3.6 学生管理界面145.3.7 班级管理界面155.3.8 任课管理界面155.3.9 学生成绩录入界面155.4 程序流程及具体实现方法155.4.1 登录模块165.4.2用户管理模块165.4.3 添加学生模块165.4.4 成绩查询模块175.4.5 其它各模块17第六章 系统运行效果176.1 系统测试及运行效果17
3、6.2 自我总体评价176.3 改进意见17第七章 结束语17致 谢17附程序源代码19基于B/S的在线成绩管理系统摘要:成绩管理是各级各类学校必不可少的一项管理工作,由于大家对学生成绩都想随时查询,因此原有的手工管理和单机管理都不能很好的满足需求。本系统利用Dreamveaver网页制作软件、运用ASP动态网页技术、以SQL Server为后台数据服务器,基于B/S环境开发,真正实现了数据共享与自动化管理,完全可以满足教师、学生及家长等对成绩随时查询的需要。本文主要阐述了在线成绩管理系统的基本设计思想、编程的技术环节、以及实现的关键技术。关键词:成绩管理、ASP、SQL SERVER、B/S
4、模式、ADO、SQL Server、VBScriptSummary : The result management is an all levels of each kind of school essential supervisory work, because everybody wants momentarily to inquire to the student achievement, therefore the original manual management and the single plane management cannot the very good satis
5、fied demand. This system using the Dreamveaver homepage manufacture software, utilizes the ASP dynamic homepage technology, take SQL Server as the backstage data server, based on the B/S environment development, has realized data sharing and the automated management truly, definitely may satisfy the
6、 teacher, the student and the guardian and so on need which momentarily inquires to the result. This article mainly elaborated the online result management system management systems basic design thought that the programming technical link, as well as realizes key technologies.Keyword : Result manage
7、ment, ASP, SQLSERVER, B/S mode, ADO, SQLServer, VBScript第一章 引 言随着科学的飞速发展,Internet这个昔日只被少数科学家接触和使用的科研工具已经发展成了普通百姓都可触及的大众型媒体传输手段。随着用户的急剧增加,Internet的应用迅速进入到文化、产业、经济、政治、新闻、体育、娱乐、商业和服务业。随着校校通工程的和中小学校园网的形成,学习和教学成为Internet的一个重要领域。它使人们可以不受时间、地域、教学水平与教学层次限制,通过Internet这一电子媒介,向人们展示了一种全新的、有别于传统的学习模式。通过这种方法,人们可以
8、足不出户,可以因人而异,把适合自己水平的教学课程通过Internet搬到家里,通过生动、形象的学习,迅速掌握自己所需要的知识。在线成绩查询是学校内部师生需求的,也是校外家长随时动态了解子女学习状况的有效途径,它不仅让学生的成绩数据真正共享了,同时也是学校提高服务与管理水平的有效方式。因此在线学生成绩管理系统的建立已势在必行。本课题的开发目的正是基于这种需求而提出的。在线成绩管理系统共分五个模块:系统管理模块、班级管理模块、课程管理模块、学生管理模块和成绩管理模块。第二章 可行性分析计算机成绩管理系统由单机版发生到局域网络版再到互联网版,现在,在线成绩管理系统是最具生命力的,单机版的计算机成绩管
9、理系统已经成为历史,局域网络版的成绩管理软件比较安全、稳定,但只能在局域网内部范围内,目前,网络程序正在向集中和分散两个方面分化,即client/server模式和pointpoint(p2p) 模式。C/S模式的网络程序主要用于企业、团体和单位,而p2p模式主要用于个体和个体之间的交互。在线成绩管理系统的设计主要是基于WEB平台和B/S模式,借助于浏览器作为客户端软件,WEB平台是服务端主要运行系统,由此开发中只需考虑服务端,更利于集中力量。在线成绩管理具有前两种成绩管理系统无法具有的优点:即远程性和实时性,所以现在中小学校也正在加大在线成绩管理系统的开发。2.1 技术可行性分析此系统采用A
10、SP技术进行开发,ASP是微软推出的一种服务器端脚本环境,它内嵌于IIS中,可让用户结合于HTML WEB页面,轻松实现与服务器的交互。ASP使用的VBScript直接来源于VB,秉承了VB简单易用的特点。本系统中要使用的数据库连接、代码安全可靠性等技术它都能提供,因而在技术上是完全可行的。2.2 经济可行性分析此系统的开发要花一定的时间与精力,也需要一定的运行资金,但总体花费不大。但它给学校成绩管理工作带来的快速、便捷以及在减少数据处理工作量、提高工作效率和质量方面所发挥的强大作用是无法用价格来估量的。何况从长远利益来年,此系统可让学校的成绩管理工作更加合理化、规范化、科学化。所以是值得投资
11、的。2.3 操作可行性分析本在线成绩管理系统在其运行上也是可行的,系统基于ASP+SQL Server模式开发,易于操作。校园网内服务器端只要对IIS作一些简单配置,客户端无需考虑,只要有IE浏览器能上网就行。所以系统在操作上是可行的。第三章 开发环境及工具3.1 开发环境(1)软件:(a) Windows 2000 Server(b) Internet Explorer 7(c) Web服务器软件(IIS 5.0)(d) SQL Server 2000(e) ASP 2.0以上(f) Dreamweaver MX 2004(2)硬件:(a) CPU P以上(b) 内存 512M以上(c) 硬
12、盘 40G以上3.2 开发工具Windows是世界上最为流行、使用最为广泛的微机图形化界面的操作系统。因此,我们选用了windows及其自带的explorer浏览器作为web站点的工作平台及www信息浏览窗口。IIS(Internet Information Server)5.0是在Windows 2000操作系统中整合最完美的Web服务器软件,目前只有IIS和PWS(Personal Web Server)支持ASP(Active Server Pages),因此,这里我选择IIS 5.0作为 Web 站点的开发和测试平台。开发基于B/S模式的在线成绩管理系统,免不了需要进行web主页的编辑
13、与设计。Micromedia公司的Dreamweaver MX 2004无疑是我们的最好选择。Dreamweaver具有强大的多媒体网页设计功能,是一款所见即所得的网页编辑软件。使用它,你不需懂得HTML语言就可以轻松地制作出自己的主页。Dreamweaver能方便地和其他图象编辑软件以及文字编辑软件高度紧密的结合,并具有开放的插件环境。你可以在网页使用插件来实现各种各样的特殊效果。如果是设计的Web应用项目的连接规模较少或者应用于小型的Intranet,我们可以选择桌面型数据库系统Access。本着系统设计的可扩充能力与适应性,进一步为未来系统的商业应用以及高的连接访问量,因此,我们选用了M
14、icrosoft的企业级规模的大型数据库系统SQL server2000作为服务器端的数据库。ASP是服务器端脚本编写环境,使用它可以创建和运行动态、交互的 Web 服务器应用程序。使用 ASP 可以组合 HTML 页、脚本命令和 ActiveX 组件以创建交互的 Web 页和基于 Web 的功能强大的应用程序。ASP 应用程序很容易开发和修改。其原理是:当客户端的浏览器从 Web 服务器上请求 .asp 文件时,ASP 脚本开始运行。然后 Web 服务器调用 ASP,ASP 全面读取请求的文件,执行所有脚本命令,并将 Web 页传送给浏览器。由于脚本在服务器上而不是在客户端运行,传送到浏览器
15、上的 Web 页是在 Web 服务器上生成的。所以不必担心浏览器能否处理脚本:Web 服务器已经完成了所有脚本的处理,并将标准的 HTML 传输到浏览器。由于只有脚本的结果返回到浏览器,所以服务器端脚本不易复制。用户看不到创建他们正在浏览的页的脚本命令。在ASP网页制作中,用来存取数据库的对象统称ADO(ActiveX Data Objects), ADO 是一项容易使用并且可扩展的将数据库访问添加到 Web 页的技术。ADO组件的功能十分强大,组件拥有的对象相当多,可以使用 ADO 去编写紧凑简明的脚本以便连接到 Open Database Connectivity (ODBC) 兼容的数据
16、库和 OLE DB 兼容的数据源。第四章 系统流程与规划4.1 系统目标规划开发此系统旨在将现代计算机技术和传统成绩管理工作相结合,并按具体学校成绩管理工作流程,设计完成一套功能较完备的符合学校管理特点的成绩管理系统。为便系统在学校的成绩管理工作中发挥更大的作用,实现工作过程计算机化,提高工作效率和质量,特提出下列目标:(1)学生成绩管理员可通过网络录入、编辑学生基本信息、成绩等。(2)大量数据录入工作中,尽量做到 录入的计算化,减少人工工作量。(3)学生可通过网络查看自己各科成绩,修改自己的基本资料。(4)查询智能化,可利用学生的一切相关信息进行学生成绩、基本信息查询。(5)注意数据的安全性
17、,具有数据备份和恢复功能。4.2 系统流程图4.3 库结构设计在网页编程中,后台数据库处于十分重要的地位。本系统使用的数据库是SQL SERVER 2000。数据库名为SCHOOL,程序将使用该库中的表有:用户表USER、学生登记表STUDENT、学期表TERM、班级表CLASS和成绩表CJB等。4.3.1 用户表USER该表主要是保存登录用户信息,系统根据登录用户的不同类型决定用户登录后可进行的具体操作,也就是对系统使用的权限。表结构设计如下:4.3.2 学生登记表STUDENT该表是用来保存学生的详细信息的资料。如果系统要扩展到学籍信息管理的话,还可以对此表进一步扩充,以达到管理学籍信息的
18、目标,但此系统没有考虑。表结构设计如下:4.3 学期表TERM该表主要是存储学期信息,每学年分第一学期与第二学期。因为现在学校对成绩的管理是按学期进行的,所以特设定此表。表结构设计如下:4.4 班级表CLASS该表主要是用来存放学校各年级的所有班级信息,现在学校对学生的管理还是以班级为单位进行。表结构设计如下:4.5 成绩表CJB该表主要是学生各学期各科目的成绩信息,是数据最多的一个表。表结构设计如下:第五章 系统的实现5.1 关键技术5.1.1 ASP技术ASP技术是一种类似HTML(Hypertext Markup Language超文本标识语言)、Script与CGI(Common Ga
19、teway Interface通用网关接口)的结合体,简单的讲它是一种运行于服务器的脚本语言,但是其运行效率比CGI更高、程序编制也比HTML更方便且更有灵活性,程序安全性及保密性也远比Script好。其特点归纳如下:ASP可以和HTML或其他脚本语言(VB Script与Java Script)互相嵌套。ASP是一种在Web服务器端运行的脚本语言,因此,程序代码完全保密。ASP以对象为基础,因此可以使用ActiveX控件继续扩充其功能。ASP内置ADO组件,因此可以轻松地存取各种数据库,大大缩短了程序开发时间。ASP可以将运行结果以HTML的格式传送至客户端浏览器,因此ASP可以适用于各种浏
20、览器。5.1.1.1 ASP及其平台运行机理介绍ASP是如何让客户看到那些动态生成的页面的,这个由我来一步步说明。用户想看一个xxx.asp的内容,就和浏览普通网页一样,那么浏览器就发出一个请求Get xxx.asp,之后IIS就收到了这个请求并发现调用的页面后缀名是ASP。经过一些简单的验证以后IIS就把手中的接力棒交给一个专门处理ASP的动态联结库,这个联结库自己有一个缓存,她一边解释这个ASP文件一边就按照程序里的要求把输出结果放到这个缓存里。最后全部解释完毕,这个缓存的内容就全部倒还给IIS,由IIS把这些结果当作一个普通网页一样(其实调用网页时也是把网页内容读入缓存再传送给用户)返回
21、给终端,然后么然后你就看到一个内容丰富的ASP页面了。既然ASP是运行在Windows2000 下,如果你使用了NTFS就一定要注意权限问题,否则有的要吃苦了。所以关于IIS的安装和虚拟目录的设置,稍后也会在文中着重指出。微软的ASP技术是一种运行于服务器端的脚本编写模型,它使开发者可以使用几乎所有的脚本语言(VBScript、Jscript或Perl等)编写脚本,这些脚本可以执行应用程序逻辑,并能够调用ActiveX组件执行特殊任务,如数据库查询、文件输入输出等。它将IDC的简单性和ISAPI的灵活性综合在一起。自从Microsoft IIS 3.0(Internet Information
22、 Server 3.0)出现以来,微软提出并一直致力于发展ASP技术。至今,ASP技术得到了进一步的发展,在IIS 4.0中提供了ASP脚本调试工具、事务处理、新的ActiveX组件、RDS等新特性。5.1.1.2 ASP的内置对象Request对象,我们知道HTTP通讯协议是一种请求与响应(Request/Response)的通讯协议,因此通常由客户端向Web服务器提出请求,Web服务器才会响应信息。因此在ASP中,特别将“客户端提出的要求”与“Web服务器响应的信息”等动作封装成Request对象与Response对象。换而言之,Request对象通常包含了用户端的相关信息,如浏览器的种类
23、、表头信息、表单参数及cookies等等。Response对象,每一种程序语言或开发工具一定都有与用户沟通的界面或函数,ASP也不例外。在ASP中负责将信息传达到用户的对象就是Response对象。Server对象,Server对象允许用户取得服务器提供的各项功能,例如,Server对象的CreateObject方法允许客户端用户建立一个ActiveX Server组件实例,其所建立组件实例会随着服务器端完成ASP网页的处理而自动被释放。如果希望此对象实例可以跨多个ASP网页,就要用到Session对象保留该组件实例,直到Session对象的运行时间到了,或是在其他ASP网页调用Session
24、对象的Abandon方法,此组件实例才会被释放。Session对象,Session对象在ASP程序编写中占了相当重的份量,由于网页是一种无状态的程序,因此几乎无法知道用户的浏览状态。必须通过Session对象记录用户的相关信息,以供用户再次对此Web服务器提出要求时作确认,例如,在某些特定的网页中,常需要用户输入确认的账号和密码,假如这些身份确认的结果无法保留,那岂不是每一个网页都需要重新输入一次密码。换而言之,每一个Session的用户,Web服务器均会自动的为它们建立一个Session。必须说明,Session对象只能适用于具备Cookie功能的浏览器。在本系统中,鉴于Session的重要
25、性,下面着重述之。Session对象拥有对每一用户会话元素的引用。ASP会话开始于用户首次访问一个ASP应用的页面。该次访问从打开浏览器或登录到应用开始,直到用户退出应用(如果应用是提供此项功能),关闭浏览器或超时。 许多Session属性(如,CodePage和Lcid)是特别针对国际化要求的。其他的则用于Session自身,如超时值和当前会话中用于跟踪用户的会话标识符等。实际上Session对象的一个限制是SessionId作为Cookie存储。它要求客户浏览器必须支持Netscape格式的Cookie. 和Application对象一样,可以将对象及其值添加到session对象中,你可以
26、直接由session对象访问一个值,或是直接从Contents或staticObject集合枚举或检索一个指定的值。(与Application对象不一样的是,但是这样做会将SESSION对象捆邦到一个特定的线程上-这意味着客户请求只能由指定线程处理,而不是下一个任意可用的线程。这将严重地影响性能。 下例添加了一个Showcontents的方法,这个方法枚举了contents集合的内容,并进行测试以保证访问到的是一个字符串。如果是,则显示它。project为asp007class为sesisnobjSub ShowContents()dim objcontent as objectcontext
27、dim sesnobj as sessiondim responseobj as response 访问内置对象Set objcontext=Getobjectcontext()Set responseobj=objContext(response)Set sesnobj=objcontext(session) 枚举集合中的值 输出字符串dim itm sesnob for each itm in sesnobj.contentsif Vartype(itm)=vbstring thenresponseobj.write itm responseobj.write end ifnext 清空S
28、et sesnobj=nothingSet responseobj=nothingSet objcontext=nothingend sub为了测试组件下面的ASP脚本创建了Contents集合中的五个项目,然后再调用组件方法: 实际上可以放弃session对象,并释放其点用的资源。举个例子,下列代码放弃了session对象,然后访问该对象,调用RseponseTst方法objWriteHeader: set sessnobject=objcontext(session) sessionobject.abandon value= sessnobject.value(value) 在调用aban
29、don方法之后,Session对象排队等待被撤消,但是只能在当前脚本完成后。因为组件方法是在脚本中被调用的,所以,在对象撤消之前组件方法就已完成。 除放弃Session对象以外,还可以为Session设置一个超时时限,以保证会话不会闲置太长的一段时间,维护一个开放的会话要消耗服务器资源,因此可用一个超时时限防止用户登录到一个会话后让计算机及会话运行使用计时器还可防止破坏会话安全,防止不在时其他人访问客户机,然后再访问需要保密的会话信息,超时时限可通过timeout属性进行设置,如下所示: sessnobject.timeout=20 超时时限为20分钟一旦会话超时,session对象拥有的任意
30、对象就被删除,访问session对象的任意一成员都会导致错误,如果组件开发者在依赖于session变量和常量创建组件时做好计划就不会发生这样的错误事件。session信息通常可用于使用于应用国际化。一个用户可能选择用俄语浏览asp应用。session对象的LCID和CodePage属性分别反映了应用中的字符串类型和asp页面使用的字符集类型。LCID属性通常用于辩别特定信息,如日期和时间采用何种形式、字符串如何排例以及其它信息。CodePage属性确定符号怎样映射到一个字符集。例如,若要设定CodePage为俄语的,须做如下设置: sessobject.CodePage=866 当然客户建立后
31、必须使用特定的CodePage和LCID值,你可以在Windows2000操作系统的帮助中找到这方面的信息.(sesson对象还有一个对话标识sessionID的引用,这个引用永远不会直接被组件开发者作为一个数据库或其它标识符,它的目的仅仅是作为一个客户浏览器与WEB服务器应用之间的会话标识符.)5.1.2 ADO技术ADO(ActiveX Data Objects)是微软公司提供给网页开发者在网页中存取数据库的最新技术,它也是ASP内置的重要组件,ADO主要的目的是为了存取或修改数据源的数据、或增加数据到指定的数据源,数据源不仅包括数据库,而且包括dBase、Excel、Foxpro、Acc
32、ess或文本文件等一些小型的数据表,所以,只要是ODBC驱动程序所能存取的数据源皆是ADO存取的对象。ADO主要是由Connection对象、Command对象、Parameter对象、Recordset对象、Field对象、Property对象及Error对象等七个对象与Fields数据集合、Properties数据集合、Parameters数据集合及Errors数据集合等四个数据集合所组合而成,其功能概述如下。5.1.2.1 ADO提供的七个对象:Connection对象负责与指定的数据源进行连接,除此之外,它还可以通过事物(Transaction)来确保在事物中所有的数据源变更的全部成功
33、。Command对象负责对数据库提供请求,也就是传递指定的SQL命令。换而言之,Command对象必须经过一个已经建立的连接(Connection对象)发出数据操作语言(DML,Data Manipulation Language)来操作数据源的数据,这些命令通常包括INSERT(增加记录)、DELETE(删除记录)、UPDATE(更新记录)、或是SELECT(以Recordset的形式选取数据)等。除此之外,也可以通过Command对象对数据库发出数据定义语言(DDL,Data Definition Language),例如CREATE TABLE(建立数据表)、DROP TABLE(删除数
34、据表)或ALTER TABLE(修改数据表结构)等。Parameter对象负责传递Command对象所需要的SQL命令参数。RecordSet对象负责浏览和操作从数据库取出的数据,换而言之,RecordSet对象就象是一个二维的数组,数组的每一行表示一个数据记录,而每个数剧列包含一个或多个数据字段,即Field对象。Field对象表示指定RecordSet对象的数据字段。Property对象表示ADO的各项对象属性值,换而言之,每个ADO对象都会有一组描述和控制对象行的属性。Error对象负责记录连接过程所发生的错误信息。5.1.2.2 ADO提供的四个数据集合:Connection对象包含E
35、rrors数据集合,在Errors数据集合中包含数剧源响应失败时所建立的Error对象。Command对象包含Parameters数据集合,在Parameters数据集合中包括Command对象所有的Parameter对象。RecordSet对象包含Fields数据集合,在Fields数据集合中包含RecordSet对象的所有Field数据字段对象。Connection对象、Command对象、RecordSet对象与Field对象皆包含一个Properties数据集合,在Properties数据集合中包含所对应Connection对象、Command对象、RecordSet对象与Field对
36、象的Property对象。ADO的七个对象及四个数据集合相互的关系图如下:图2ActiveX Data Object关系图5.1.3 SQL Server数据库本系统所使用的数据库服务器为SQL Server2000, SQL Server2000是基于客户/服务器(Client/Server)结构的关系型数据库管理系统(RDBMS)。它在SQL Server7.0的基础上,扩展了SQL Server的总体功能与性能、工具界面更加方便合理、全面的数据完整性保护、系统安全性更高。SQL Server2000摒弃了老版本中的Device,数据库空间不会受限于Device空间大小,方便了数据空间的扩
37、展,使SQL Server2000作为一个网络数据库管理系统,其扩展已超出了单个物理计算机的限制,并且多服务器“分布式”事物的内在支持更加充分。下面简单介绍一下与本系统有关的几个技术。5.1.3.1 SQL Server安全性管理可以这样说,一个数据库服务器不外乎强调两种功能:数据库记录完整性、数据存取安全性。而在SQL Server2000中提供了一个非常强大的安全性管理功能,它可以分成两种。SQL Server身份确认模式。用户可以直接在SQL Server中创建登录数据库服务器的独立账号,而这样的账号无须与NT域账号具有任何关系,是属于SQL Server这一层的账号管理,一般称之为St
38、andard模式,当创建一个SQL Server Standard账号之后,还可以根据需要设定其服务器管理操作与前台应用系统存取数据权限。采用NT域账号。SQL Server支持的另一种安全性方式是采用NT Domain账号,也就是说可以将NT Domain账号应用在SQL Server中,让用户通过前台工作站登录网络之后,即可通过这样的网络账号直接登录SQL Server,无须再重新登录。本系统采用了第一种模式,以超级用户”sa”登录,拥有一切操作和权限。出于安全考虑,在实际应用中应该创建一个新的SQL Server Standard账号,并仔细设定其操作与权限。5.1.3.2 创建数据库及
39、数据表SQL Server2000的Enterprise Manager管理工具是一个非常好用的可视化管理工具,根据屏幕说明,和利用鼠标操作,就能很快地创建一个数据库及其表结构,这里不再多介绍。值得一提的是SQL Server7.0中提供的datetime和text两种字段类型,其中datetime是用来保存日期和时间数据的,text是用来保存不定长度的备注说明内容的,有了这两个数据类型,应用系统中就不用再为输出格式和限制字符串长度而增加额外代码了。5.1.3.3 存储过程Stored Procedure所谓Stored Procedure实际上就是一段保存在数据库中的程序,通过一个名称的命名
40、,其中包含有处理数据库存取与运算的SQL语句,并且将这样的程序文件紧密结合在数据库中,这样我们的前台应用系统在执行过程中,可以直接执行数据库中设置好的Stored Procedure,甚至可以传递参数。其特性为,建立最佳的数据存取与处理效率,因为Stored Procedure一经执行之后,可以进行编译,并且放置在后台的Cache中,可以允许其他人直接执行。在本BBS系统中运用了大量的Stored Procedure,用来保存需要反复使用的,规则性的,处理数据库的SQL过程,如此一来,增进了系统的处理效率,同时也提高了系统的维护能力。5.1.4 VBScript及JavaScript脚本语言S
41、cript(脚本)是由一组可以在客户端浏览器上运行的命令组合而成的语言,你可以把它想像成一个运行于客户端上的可执行程序。目前在网页编制上比较流行的脚本语言包括VBScript及JavaScript。它们都是一种与HTML语言相似的描述性语言,也是以文本形式存在,不像C语言或Java语言那样,需要编译连接成字节码形式的可执行程序。Script语句可以单独存成文档,也可以被嵌入到HTML的文件之中,与HTML语句结合在一起。当需要将Script语句直接加入到HTML文件中时,只要使用一个HTML标记符号即可。例如: temp var i = 10;document.write (i);This i
42、s a JavaScript example.另外,Script程序在HTML中的位置也比较自由,它可以在HTML文件中的任何位置。脚本语言是一种解释性语言,可以直接由浏览器来解释执行。并且可以直接访问浏览器中的各种对象,如窗口对象、文档对象、框架对象、超链接对象等。脚本语言可以实现的功能很多,可以用于定义网页、在网页中加入动画、对网页中的各种元素进行处理,特别是在处理表单方面有很强功能。不仅如此,它还可以很方便地控制浏览器中的各对象的属性。例如,可以实现打开或关闭浏览器窗口、设置窗口状态、改变窗口中的超链接位置等。总之,一些常用的功能都可以用脚本语言实现。本系统中就运用了大量的脚本语言,一方
43、面用来完成表单提交前的数据验证任务,另一方面用来完成打开新的窗口、关闭当前窗口、返回前一页及下拉菜单等功能。通过使用脚本语言既防止了大量错误数据被提交到服务器,进而节约了宝贵的系统资源;也使网页更加美观、操作更加方便。大大提高了系统的性能。5.2 实现方法5.2.1 数据库连接方式在ASP脚本中可以通过三种方式访问数据库:传统的IDC(Internet Database Connector)方式,ADO(ActiveX Data Objects)方式以及RDS(Remote Data Service)方式。从概念上来讲,这三种访问方式对数据库的访问是由Internet Information
44、Server来完成的。如图1所示。 Web浏览器用HTTP协议向Internet信息服务器(IIS)递交请求。Internet信息服务器执行访问数据库的操作,并以一个HTML格式的文档作为回答。(1)Internet数据库接口(IDC)IDC是一个传统的数据库查询工具,用来定义和执行数据库查询的SQL命令,并向浏览器返回一个指定数据格式的页面。使用IDC访问数据库最大的特点是简单,几乎不需要编程就能实现对数据库的(2)ActiveX数据对象(ADO)与IDC不同,用ADO访问数据库更类似于编写数据库应用程序,ADO把绝大部分的数据库操作封装在七个对象中,在ASP页面中编程调用这些对象执行相应的
45、数据库操作。ADO是ASP技术的核心之一,它集中体现了ASP技术丰富而灵活的数据库访问功能。ADO建立了基于Web方式访问数据库的脚本编写模型,它不仅支持任何大型数据库的核心功能,而且支持许多数据库所专有的特性。ADO使用本机数据源,通过ODBC访问数据库。这些数据库可以是关系型数据库、文本型数据库、层次型数据库或者任何支持ODBC的数据库。ADO的主要优点是易用、高速、占用内存和磁盘空间少,所以非常适合于作为服务器端的数据库访问技术。相对于访问数据库的CGI程序而言,它是多线程的,在出现大量并发请求时,也同样可以保持服务器的运行效率,并且通过连接池(Connection Pool)技术以及对
46、数据库连接资源的完全控制,提供与远程数据库的高效连接与访问,同时它还支持事务处理(Transaction),以开发高效率、高可靠性的数据库应用程序。正是因为使用ADO需要编写脚本程序,所以ADO能够实现更复杂、更灵活的数据库访问逻辑。目前,ADO包括Command、Connection、Recordset等七个对象和一个动态的Properties集合,绝大部分的数据库访问任务都可以通过它们的组合来完成。一般使用ADO访问数据库的ASP脚本程序应该使用Connection对象建立并管理与远程数据库的连接;使用Command对象提供灵活的查询;而使用Recordset对象访问数据库查询所返回的结果
47、。这三者是ADO中最基本也最核心的对象。(3)远程数据服务(RDS)RDS是IIS 4.0中新提出的概念,它是由ASP中原来的Advanced Data Connector(ADC)发展而来的。在IIS 4.0中,RDS与ADO集成到一起,使用同样的编程模型,提供访问远程数据库的功能。由于RDS与ADO集成,RDS的底层是调用ADO来完成的,所以也可以将RDS理解为ADO的RDS,即ActiveX数据对象的远程数据服务。所以RDS同样具有ADO的易用性,区别仅在于RDS需要与数据绑定控件一同使用,比如Sheridan的ActiveX DataBound Grid控件。正如ADO类似于VB中的RDO一样,RDS也类似于VB中的远程数据控件(RDC)。 ASP中五种连接数据库的方法:.:.第一种 - 这种方法用在ACCESS中最多strconn = DRIVER=Microsoft Access Driver (*.mdb);DBQ= & Server.MapPath(aspfree.mdb)set conn = server.createobject(adodb.connection)co