下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于Web的交互式数据库查询技术来源: (咱要学.中国资源门户) 作者:唐雪峰 赵保华编辑: 塞外游侠 摘要: 介绍通过Web服务器实现数据库动态数据交互的几种方法及其对比,着重以实例说明如何实现与DBASE x和ORACLE数据库的交互操作。关键词:Web, CGI,ISAPI,ASP 1 概述Web技术是一项很新的技术,它不仅为Internet的广泛普及起到关键性的作用,而且还在其他相关计算机网络应用技术发展中起到关键作用,例如Intranet、电子商务等,目前它已成为计算机网络应用的一个主要技术,尤其重要的技术是web动态技术,与后台数据库的交互式动态查询技术。本文针对常用的web动态技
2、术,与数据库交互技术作以介绍。2 实现Web动态技术的几种方法2.1 利用CGI实现Web动态技术在Web应用中,与其他动态编程技术相比,CGI技术虽然是一项很早期的技术,有很多的不足,性能差、需要大量的HTTP知识、不灵活等等,但笔者认为它还是具有很强的使用性,因为其使用普遍,很多Web服务器均支持。就其协议而言,具有简单、易掌握,见效快等特点。因此本文介绍的应用实例主要是基于它的。CGI是Common Gateway Interface的缩写,目前大多数的Web产品提供此项服务功能,它可以使用任何一种计算机语言编写,使用尤其广泛的有C、Perl、C+语言,在Internet上有很多相关的资
3、料和程序及源代码。它的运行过程如图1,Web服务器接受客户端浏览器的RL请求,找到CGI程序后,启动并产生一个CGI进程,将系统参数和用户请求参数交给CGI进程,由CGI进程提取数据库中数据处理后,产生结果,反馈给Web服务器,由其反馈给用户端浏览器。这样完成了一个请求过程。图 CGI调用流程(略)IDC(Internet数据库连接器) 通过使用Internet数据库连接器可以发布你的数据库,允许用户访问数据,只需开发者编写最少量的代码。你只需提供SQL查询(IDC将在数据库上执行它)和模板(描述数据显示和收集的方式),而不用进行复杂的程序设计,这种方法适用于简单的不需要控制和验证数据的程序。
4、它是IIS的功能之一 ,IIS通过调用一个名为HTTPODBC.DLL的ISAPI应用程序处理.IDC和.HTX文件实现的,调用处理过程如图,它是一个不连续的循环。应用中要注意隐藏.IDC和.HTX文件。保证应用程序和数据库的安全性。图IDC应用程序的处理过程(略)基于ISAPI的解决方案 ISAPI(Internet Server Application Programming Interface)是Microsoft的IIS提供的一种新的接口标准,用于开发交互式Web应用程序,它采用的语言多为面向对象的编程语言如Visual C+、Delphi等,它与CGI程序很相似,但在性能方面较CGI
5、应用程序相比有较大提高,在执行时不需要重复装入代码,能够降低系统开销,提高运行速度;具有很强的灵活性,与服务器之间能够很好的衔接,能够实现一些很复杂的操作和控制。分为ISAPI扩展程序和ISAPI过滤器两种方式,前者主要完成类似CGI程序的功能,后者能够实现与IIS的更完美的结合,可以监督所有的验证请求或所有服务器发送到用户的数据,过滤器跨越整个服务器,并能影响服务器的工作方式但ISAPI编程需要开发者有熟练的经验,特别对服务器操作、客户端与服务器之间的通讯方式的较深的理解和娴熟的编程技巧。活动服务器页面(Active Server Pages) 它是由第三版IIS提供的新特性,实质是通过一个
6、名为sspifilt.dll的ISAPI过滤器实现的,主要提供的功能是开发人员可以通过使用服务器端脚本(VBScript或VCScript)动态生成网页,可以同访问数据库的ActiveX控件连接在一起使用来实现数据库的动态交互查询。是目前较新的一种技术。第三方解决方案 许多第三方工具可以用来帮助你创建交互式Web应用程序,它们主要改善了CGI程序的开发环境,降低开发人员掌握基于Web的数据库交互式应用程序的开发难度,帮助你使用所熟悉环境来开发应用程序,保存现有应用程序代码的移植和复用性。值得一提的产品有以下几种产品:WebAction是classTools公司的产品,网址:Tornado 网址
7、:WebHub是HREF Tools公司的产品,网址:Foxweb是Fox公司的产品,网址:几种常用方法的对比 见表1。方法名称对比 项目基于CGI技术数据库连接器IDC 基于ISAPI 活动服务器页面ASP 第三方解决方案 操作 系统几乎任何操作系统 Window NT Window NT Window NT 与具体产品有关 Web 服务器主流Web服务器均支持 IIS IIS IIS 与具体产品有关 运行 速度每次请求均需要调入一次程序,随着请求数量增加而变慢基于ISAPI扩展解释方式,速度由于其与操作系统和Web服务器结合紧密其速度快中一般较慢 对编程人员要求需要对HTTP、HTML、T
8、CPIP和CGI协议,SQL、至少一种计算机编程语言熟悉HTML、SQL、IDC嵌入脚本面向对象的编程语言Delphi、Visual C+,熟悉网络环境和协议、数据库接口需要熟悉HTML、Jscript或VBScripts脚本语言、SQL 有初步的HTML和网络知识和产品要求的编程语言 培训对于网络环境用户较为容易容易较难较易容易 适于程序规模任何规模小特殊要求或规模性程序中小中小 表1 几种常用方法的对比3 实例针对大庆采油四厂的具体情况,主要以DbaseX数据库和Oracle数据为主,我们主要采取两种方式,DbaseX类型数据库一般存放在Window NT Server上,多数编程人员多适
9、应Xbase语言的编程,我们采用第三方产品,在服务器端安装Foxweb产品,这样保证了现有软件开发人员能够利用Foxpro进行CGI程序编制达到交互目的,有助于使现有程序员较为容易的掌握,从而尽快产生良好的效果。安装Foxweb产品后,其中一个名字为Foxweb.exe的文件相当于一个普通的CGI程序,安装在Web服务器的CGI目录下,用Vfoxpro编写的程序需要有它来解释后执行。在Foxweb中提供全局变量“CGI.参数名字”和下面3个函数主要是传递客户端和服务器端的一些信息和解释、提取超文本表单的用户请求数据和合并混有普通visual Foxpro程序数据变量的超文代码,是其成为用户能够
10、浏览的信息。Foxpro程序员只需对这些有一个透彻的理解并掌握一定超文本知识就能够进行基于web的编程。?FormField():返回表单中变量的值 ?TotFields():对于多选值变量,判定变量值个数 ?MergeTxt():替换merge编码中的<< 和 >>之间的变量 Oracle数据库主要采用的是,服务器端直接安装Oracle公司提供的Web服务功能,在此基础上进行二次开发,或利用Oracle产品的Pro*C和SQL查询语言直接编写CGI程序来达到交互使用,或使用ODBC或JDBC数据库接口产品与数据库进行交互式操作。客户端的动态方式,一种利用HTML的表单
11、和RL的附加查询串向服务器的CGI程序传递请求,CGI程序将数据以超文本形式返回给客户,这种方式可以通过一些嵌入的脚本语言来进行表单的预处理,来减少CGI程序的负荷,提高CGI的执行效率。另一种方式是采用JAVA Applet进行交互,这样可以使程序具有更好的交互性,图形化,而且这样由于JAVA Applet是下载到客户端运行的,而且JAVA Applet有很强的图形处理和应用程序接口能力,这样CGI程序只需将基本数据提取后,返回到客户端即可,这样可以大大降低服务器端的负荷,将运算量分散到客户端,使得负荷得到均衡。在实现这些内容时,数据库的接口也是一个很重要的方面,下面列出CGI程序、ODBC
12、、JDBC、JAVA Applet之间的数据交换简图和基本步骤,无论如何在使用这些之前,都需要在数据库服务器上建立相应驱动程序和数据源,详细内容请查阅本文后面列出的书籍。图3使用ODBC访问数据库(略)使用ODBC的基本步骤是:见图3所示。为ODBC分配环境句柄 分配一个连接句柄 连接到数据库 用SQL命令分配一个语句句柄 传送该语句 关闭连接 解除连接和环境句柄图4使用JDBC访问数据库(略)使用JDBC的基本步骤是:见图4所示。建立连接 创建Statement对象,用于执行SQL语句 执行SQL语句 关闭Statement对象 关闭连接 结论本文介绍的基于Web交互式数据库查询技术中,基于FOXWEB CGI和基于JAVA ,ODBC针对ORACLE的CGI编程技术已广泛应用于大庆采油四厂生产开发信息查询系统中,具有很强的实用性。随着新技术的不断出现和编程人员对Web和网络知识的了解和深入,我们可以采用更新、更好的技术的解决方案,特别是NT服务器IIS的ISAPI技术。参考文献(1) 吴迪文, WW
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026江西鹰潭月湖区民政局招聘工作人员1人备考题库附答案详解(精练)
- 2026中国科学院青藏高原所“海外优青”项目人才招聘备考题库(北京)及答案详解(历年真题)
- 2026海南琼海市就业局公益性岗位招聘备考题库及答案详解【考点梳理】
- 2026山西省气象局招聘应届高校毕业生12人备考题库(第2号)带答案详解(综合题)
- 何时恢复电力工作制度
- 人防业务工作制度范本
- 卫生局科教科工作制度
- 中心小学教研工作制度
- 产科胎盘处置工作制度
- 一汽大众天津工作制度
- 新疆东明塑胶有限公司年产3万吨多晶硅项目环评报告
- 2025年重庆市中考语文真题(原卷版)
- DB31/T 1333-2021城市供水管网运行安全风险监测技术规范
- 2025年人教版小学六年级下册奥林匹克数学竞赛测试卷(附参考答案)
- 危化品卸车试题及答案
- 食品生产许可现场核查评分表SC模板
- 胶合板生产流程
- 美发店卫生管理制度
- 门诊患者心理特点及护理
- 超星尔雅学习通《法律基础(西南政法大学)》2025章节测试答案
- 《计算机动漫与游戏制作教程》课件-第1章
评论
0/150
提交评论