下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基于Web的交互式数据库查询技术
摘要:介绍通过Web服务器实现数据库动态数据交互的几种方法及其对比,着重以实例说明如何实现与DBASEx和ORACLE数据库的交互操作。关键词:Web,CGI,ISAPI,ASP1概述Web技术是一项很新的技术,它不仅为Internet的广泛普及起到关键性的作用,而且还在其他相关计算机网络应用技术发展中起到关键作用,例如Intranet、电子商务等,目前它已成为计算机网络应用的一个主要技术,尤其重要的技术是web动态技术,与后台数据库的交互式动态查询技术。本文针对常用的web动态技术,与数据库交互技术作以介绍。2实现Web动态技术的几种方法2.1利用CGI实现Web动态技术在Web应用中,与其他动态编程技术相比,CGI技术虽然是一项很早期的技术,有很多的不足,性能差、需要大量的HTTP知识、不灵活等等,但笔者认为它还是具有很强的使用性,因为其使用普遍,很多Web服务器均支持。就其协议而言,具有简单、易掌握,见效快等特点。因此本文介绍的应用实例主要是基于它的。CGI是CommonGatewayInterface的缩写,目前大多数的Web产品提供此项服务功能,它可以使用任何一种计算机语言编写,使用尤其广泛的有C、Perl、C++语言,在Internet上有很多相关的资料和程序及源代码。它的运行过程如图1,Web服务器接受客户端浏览器的URL请求,找到CGI程序后,启动并产生一个CGI进程,将系统参数和用户请求参数交给CGI进程,由CGI进程提取数据库中数据处理后,产生结果,反馈给Web服务器,由其反馈给用户端浏览器。这样完成了一个请求过程。图1CGI调用流程(略)IDC(Internet数据库连接器)通过使用Internet数据库连接器可以发布你的数据库,允许用户访问数据,只需开发者编写最少量的代码。你只需提供SQL查询(IDC将在数据库上执行它)和模板(描述数据显示和收集的方式),而不用进行复杂的程序设计,这种方法适用于简单的不需要控制和验证数据的程序。它是IIS的功能之一,IIS通过调用一个名为HTTPODBC.DLL的ISAPI应用程序处理.IDC和.HTX文件实现的,调用处理过程如图2,它是一个不连续的循环。应用中要注意隐藏.IDC和.HTX文件。保证应用程序和数据库的安全性。图2IDC应用程序的处理过程(略)基于ISAPI的解决方案ISAPI(InternetServerApplicationProgrammingInterface)是Microsoft的IIS提供的一种新的接口标准,用于开发交互式Web应用程序,它采用的语言多为面向对象的编程语言如VisualC++、Delphi等,它与CGI程序很相似,但在性能方面较CGI应用程序相比有较大提高,在执行时不需要重复装入代码,能够降低系统开销,提高运行速度;具有很强的灵活性,与服务器之间能够很好的衔接,能够实现一些很复杂的操作和控制。分为ISAPI扩展程序和ISAPI过滤器两种方式,前者主要完成类似CGI程序的功能,后者能够实现与IIS的更完美的结合,可以监督所有的验证请求或所有服务器发送到用户的数据,过滤器跨越整个服务器,并能影响服务器的工作方式.但ISAPI编程需要开发者有熟练的经验,特别对服务器操作、客户端与服务器之间的通讯方式的较深的理解和娴熟的编程技巧。活动服务器页面(ActiveServerPages)它是由第三版IIS提供的新特性,实质是通过一个名为sspifilt.dll的ISAPI过滤器实现的,主要提供的功能是开发人员可以通过使用服务器端脚本(VBScript或VCScript)动态生成网页,可以同访问数据库的ActiveX控件连接在一起使用来实现数据库的动态交互查询。是目前较新的一种技术。第三方解决方案许多第三方工具可以用来帮助你创建交互式Web应用程序,它们主要改善了CGI程序的开发环境,降低开发人员掌握基于Web的数据库交互式应用程序的开发难度,帮助你使用所熟悉环境来开发应用程序,保存现有应用程序代码的移植和复用性。值得一提的产品有以下几种产品:WebAction是classTools公司的产品,网址:/Tornado网址:/tornado.htmWebHub是HREFTools公司的产品,网址:/Foxweb是Fox公司的产品,网址:/几种常用方法的对比见表1。对比项目表1几种常用方法的对比3实例针对大庆采油四厂的具体情况,主要以DbaseX数据库和Oracle数据为主,我们主要采取两种方式,DbaseX类型数据库一般存放在WindowNTServer上,多数编程人员多适应Xbase语言的编程,我们采用第三方产品,在服务器端安装Foxweb产品,这样保证了现有软件开发人员能够利用Foxpro进行CGI程序编制达到交互目的,有助于使现有程序员较为容易的掌握,从而尽快产生良好的效果。安装Foxweb产品后,其中一个名字为Foxweb.exe的文件相当于一个普通的CGI程序,安装在Web服务器的CGI目录下,用Vfoxpro编写的程序需要有它来解释后执行。在Foxweb中提供全局变量“CGI.参数名字”和下面3个函数主要是传递客户端和服务器端的一些信息和解释、提取超文本表单的用户请求数据和合并混有普通visualFoxpro程序数据变量的超文代码,是其成为用户能够浏览的信息。Foxpro程序员只需对这些有一个透彻的理解并掌握一定超文本知识就能够进行基于web的编程。?FormField():返回表单中变量的值?TotFields():对于多选值变量,判定变量值个数?MergeTxt():替换merge编码中的<<和>>之间的变量Oracle数据库主要采用的是,服务器端直接安装Oracle公司提供的Web服务功能,在此基础上进行二次开发,或利用Oracle产品的Pro*C和SQL查询语言直接编写CGI程序来达到交互使用,或使用ODBC或JDBC数据库接口产品与数据库进行交互式操作。客户端的动态方式,一种利用HTML的表单和URL的附加查询串向服务器的CGI程序传递请求,CGI程序将数据以超文本形式返回给客户,这种方式可以通过一些嵌入的脚本语言来进行表单的预处理,来减少CGI程序的负荷,提高CGI的执行效率。另一种方式是采用JAVAApplet进行交互,这样可以使程序具有更好的交互性,图形化,而且这样由于JAVAApplet是下载到客户端运行的,而且JAVAApplet有很强的图形处理和应用程序接口能力,这样CGI程序只需将基本数据提取后,返回到客户端即可,这样可以大大降低服务器端的负荷,将运算量分散到客户端,使得负荷得到均衡。在实现这些内容时,数据库的接口也是一个很重要的方面,下面列出CGI程序、ODBC、JDBC、JAVAApplet之间的数据交换简图和基本步骤,无论如何在使用这些之前,都需要在数据库服务器上建立相应驱动程序和数据源,详细内容请查阅本文后面列出的书籍。图3使用ODBC访问数据库(略)使用ODBC的基本步骤是:见图3所示。为ODBC分配环境句柄分配一个连接句柄连接到数据库用SQL命令分配一个语句句柄传送该语句关闭连接解除连接和环境句柄图4使用JDBC访问数据库(略)使用JDBC的基本步骤是:见图4所示。建立连接创建Statement对象,用于执行SQL语句执行SQL语句关闭Statement对象关闭连接结论本文
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 简单离婚协议书范文
- 简易工厂转让合同范本
- 淋浴房工程变更与索赔合同
- 国有企业增资协议书范本
- 借车合同范本
- 2024年度网络安全防护系统设计与施工总承包合同
- 基于2024年度的物流服务合同
- 树木买卖合同纠纷树木买卖合同
- 体育中心场地出租合同
- 男方自愿净身出户离婚协议书完整版
- 部编人教版2022-2023学年度第一学期四年级道德与法治上册期末测试卷及答案
- 统编版(2024)语文七年级上册 第10课 往事依依 公开课一等奖创新教案
- 全国巾帼家政服务职业技能大赛(母婴护理员)理论考试题库(含答案)
- 员工食堂消防应急预案
- 离婚协议书常用范本2024年
- 2024年各地中考语文卷【综合性学习题】汇集练附答案解析
- 个人情况说明怎么写
- 第20课 三国两晋南北朝时期的科技与文化-2024-2025学年初中历史七年级上册上课课件
- 名著导读 《昆虫记》教学设计2024-2025学年统编版语文八年级上册
- 数学-广东省2025届广州市高三年级上学期阶段性训练暨8月摸底考试试题和答案
- 2024年人民日报社招聘应届高校毕业生85人笔试(高频重点复习提升训练)共500题附带答案详解
评论
0/150
提交评论