您现在的位置: 范文先生网 >> 理工论文 >> 计算机论文 >> 正文

基于Web的交互式数据库查询技术

时间:2007-1-30栏目:计算机论文

基于Web的交互式数据库查询技术

中国科学技术大学计算机系  唐雪峰 赵保华

摘要: 介绍通过Web服务器实现数据库动态数据交互的几种方法及其对比,着重以实例说明如何实现与DBASE x和ORACLE数据库的交互操作。

关键词:Web, CGI,ISAPI,ASP

1 概述

Web技术是一项很新的技术,它不仅为Internet的广泛普及起到关键性的作用,而且还在其他相关计算机网络应用技术发展中起到关键作用,例如Intranet、电子商务等,目前它已成为计算机网络应用的一个主要技术,尤其重要的技术是web动态技术,与后台数据库的交互式动态查询技术。本文针对常用的web动态技术,与数据库交互技术作以介绍。

2 实现Web动态技术的几种方法

2.1 利用CGI实现Web动态技术

在Web应用中,与其他动态编程技术相比,CGI技术虽然是一项很早期的技术,有很多的不足,性能差、需要大量的HTTP知识、不灵活等等,但笔者认为它还是具有很强的使用性,因为其使用普遍,很多Web服务器均支持。就其协议而言,具有简单、易掌握,见效快等特点。因此本文介绍的应用实例主要是基于它的。

CGI是Common Gateway Interface的缩写,目前大多数的Web产品提供此项服务功能,它可以使用任何一种计算机语言编写,使用尤其广泛的有C、Perl、C++语言,在Internet上有很多相关的资料和程序及源代码。

它的运行过程如图1,Web服务器接受客户端浏览器的URL请求,找到CGI程序后,启动并产生一个CGI进程,将系统参数和用户请求参数交给CGI进程,由CGI进程提取数据库中数据处理后,产生结果,反馈给Web服务器,由其反馈给用户端浏览器。这样完成了一个请求过程。

图1 CGI调用流程(略)

IDC(Internet数据库连接器)
通过使用Internet数据库连接器可以发布你的数据库,允许用户访问数据,只需开发者编写最少量的代码。你只需提供SQL查询(IDC将在数据库上执行它)和模板(描述数据显示和收集的方式),而不用进行复杂的程序设计,这种方法适用于简单的不需要控制和验证数据的程序。它是IIS的功能之一 ,IIS通过调用一个名为HTTPODBC.DLL的ISAPI应用程序处理.IDC和.HTX文件实现的,调用处理过程如图2,它是一个不连续的循环。应用中要注意隐藏.IDC和.HTX文件。保证应用程序和数据库的安全性。

图2IDC应用程序的处理过程(略)

基于ISAPI的解决方案
ISAPI(Internet Server Application Programming Interface)是Microsoft的IIS提供的一种新的接口标准,用于开发交互式Web应用程序,它采用的语言多为面向对象的编程语言如Visual C++、Delphi等,它与CGI程序很相似,但在性能方面较CGI应用程序相比有较大提高,在执行时不需要重复装入代码,能够降低系统开销,提高运行速度;具有很强的灵活性,与服务器之间能够很好的衔接,能够实现一些很复杂的操作和控制。分为ISAPI扩展程序和ISAPI过滤器两种方式,前者主要完成类似CGI程序的功能,后者能够实现与IIS的更完美的结合,可以监督所有的验证请求或所有服务器发送到用户的数据,过滤器跨越整个服务器,并能影响服务器的工作方式.但ISAPI编程需要开发者有熟练的经验,特别对服务器操作、客户端与服务器之间的通讯方式的较深的理解和娴熟的编程技巧。

活动服务器页面(Active Server Pages)
它是由第三版IIS提供的新特性,实质是通过一个名为sspifilt.dll的ISAPI过滤器实现的,主要提供的功能是开发人员可以通过使用服务器端脚本(VBScript或VCScript)动态生成网页,可以同访问数据库的ActiveX控件连接在一起使用来实现数据库的动态交互查询。是目前较新的一种技术。

第三方解决方案
许多第三方工具可以用来帮助你创建交互式Web应用程序,它们主要改善了CGI程序的开发环境,降低开发人员掌握基于Web的数据库交互式应用程序的开发难度,帮助你使用所熟悉环境来开发应用程序,保存现有应用程序代码的移植和复用性。值得一提的产品有以下几种产品:

WebAction是classTools公司的产品,网址:http://www.classtools.com/

Tornado 网址:http://www.eudev.com/tornado.htm

WebHub是HREF Tools公司的产品,网址:http://www.href.com/

Foxweb是Fox公司的产品,网址:http://www.foxweb.com/

几种常用方法的对比 见表1。

方法

名称

对比 项目

基于CGI技术数据库连接器IDC 基于ISAPI 活动服务器页面ASP 第三方解决方案 操作 系统几乎任何操作系统 Window NT Window NT Window NT 与具体产品有关 Web 服务器主流Web服务

[1] [2] [3] 下一页

下页更精彩:1 2 3 4 下一页