·您的位置: 首页 » 资源教程 » 编程开发 » ASP » ASP中ACTIVEX控件的内嵌及调用

ASP中ACTIVEX控件的内嵌及调用

类别: ASP教程  评论数:0 总得分:0
懂ASP(Active Server Pages)的人很多,但能用ASP自如地调用ActiveX控件的人却不多;如果不调用ActiveX控件,则可以说微软当初设计ASP的初衷根本没有达到。众所周知,ActiveX技术是微软在Internet上除了IE外的另一个新举措,可以说该技术渗透在它的整个Internet策略中。ActiveX是一个功能强大的部件,可以用VB、C或C++等语言进行编写,因为是编译性执行,故速度比较快。 在ASP(Active Server Pages)中内建了多个功能强大的ActiveX Server控件,包括Ad Rotator(动态广告生成控件)、BrowserType Capabilities(浏览器相容控件)、Database Access(数据库存取控件)、Content Linking(文件链接控件)和File Access Component(文件存取控件)等。当然,ASP除了可以调用内嵌的ActiveX控件外,还可以调用其他用户编写的标准的ActiveX控件。

   在使用控件前先要进行定义,如:<% Set对象变量名称=Server.CreateObject("ADODB.Connection") %>,或直接用HTML的<OBJECT>和</OBJECT>标记进行定义,效果一样。

  例:<OBJECT RUNAT=SERVER

   ID=对象变量名称

   PROGID="ADODB.Connection">

   </OBJECT>

  定义好后,我们就可以开始调用它的方法来配合相关工作的进行。

  

   一.内嵌各种ActiveX控件的方法和属性

   1.Database Access(数据库存取控件)

   这是一个非常重要的部分,因为50%以上的工作几乎都要涉及到数据库,使用该控件可以说是必不可少的。在ASP中使用ADO(Active Data Objects)来存取数据库资料,如果是远程的数据源,则可采用RDO(Remote Data Objects)。ADO包括以下七个对象类。

   Command:定义一些特别的命令语法,让你可以执行相应的程式。

   Connection:提供对OLE DB信息源的链接。

   Error:用来描述存取数据库时发生的错误。

   Field:以行作为读取信息单元。

   Parameter:使用Command时需传入的参数。

   Property:记录ADO对象的动态特性。

   Recordset:用来保存读取回来的数据库信息。

   下面以一个最普通的例子来说明读取数据库信息、然后发布该信息的步骤。首先在ODBC Driver里建立一个名字为test的System DSN,链接到你的任意一个数据库上;然后用写字板创建一个后缀名为.asp的文本,内容如下。

   <HTML><BODY>

   <%

   set DC=CREATEOBJECT("ADODB.CONNECTION")

   ;定义一个DC为Connection的对象

   DC.OPEN "test"

   ;OPEN是Connection的一个方法,如果你链接的是Access或Foxpro数据库,则可采用上面的方法,如果是其他类似于sql、oracle等需要用户名和密码才允许访问的数据库,则可通过DC.OPEN"test","uid","password"来打开数据库源。

   SQL="select * FROM JOB"

   set RESULT=DC.EXECUTE(SQL)

   ;EXECUTE是Connection的另一个方法,用于执行SQL语句。这里定义RESULT为RECORDSET对象,用于接收SQL语句执行后的返回结果。如果不需要保存返回结果,则可直接调用“DC.EXECUTE SQL"。

   DO WHILE NOT RESULT.EOF

   RESPONSE.WRITE RESULT("NAME")

   ;假设NAME是数据库的一个属性。

   RESULT.MOVENEXT

   ;除了MOVENEXT外,还有MOVEFIRST、MOVELAST等方法,与VB类似。

   LOOP

   RESULT.CLOSE

   %>

   </BODY></HTML>

   从上面的例子中,我们可以清楚地看到,链接OLE DB信息源最常用的类是Connection类,其方法包括OPEN、EXECUTE、CLOSE、BEGINTRANS、COMMITTRANS和ROLLBACKTRANS。如果你很熟悉SQL Script中的回滚操作,那么对BEGINTRANS一定不会感到陌生,最后三个方法是用于对一些事件进行回滚的操作,其语法如下(要补充的一点是,如果你能在数据库里完成回滚的操作,那么最好在数据库里进行,因为这样效率会更高,对系统的影响也就会更少)。

   BEGINTRANS

   语法:[level=]Connection 对象.BeginTrans

   其中level是一long类型的变数,用来存储BeginTrans方法所传回的level值。

   COMMITTRANS

   语法:Connection 对象.CommitTrans

   存储当前的所有动作和结果。

   ROLLBACKTRANS

   语法:Connection 对象.RollbackTrans

   取消所有从BeginTrans开始的工作并重新进行初始化。

   这里只对最常用的Connection类进行了详细的介绍,如果希望进一步了解Database Access其他类库,可访问http://www.microsoft.com/ado/站点。

  

   2.Ad Rotator(动态广告生成控件)

  广告在网络上的效果越来越为人们所认识,“网盟”(WebUnion)就是一个很好的范例。一个好的广告发布程序并不容易编写,因为你要考虑包括图片出现的频度、图片的名字、链接的地址、显示的尺寸、还有速度、效率和维护等诸多的问题。当然,如果你们是一个象WebUnion这样的大型站点,则这是必须的;但如果你们只是一个小站点,只是希望简单地动态显示一些图片(包括链接)和方便维护,那么Ad Rotator动态广告生成控件绝对是你的首选。

   为了使你有一个直观的认识,我们将先介绍建立动态广告的步骤,然后再细述其方法。产生动态广告,要涉及到三个文件:主文件main.asp、文本文件info.txt、副文件redi.asp。

   main.asp为要显示广告的页面,内容为:

  <% Set ad=Server.CreateObject("MSWC.AdRotator")%>

  <%= ad.GetAdvertisement("info.txt")%>

  第一行是创建Ad Rotator类的对象,第二行用于取得广告资料。

   info.txt是广告的资料,内容为:

  redirect redi.asp

  width 400

  height 60

  border 1

  *

  

  1.jpg

  http://www.gznet.com

  广州视窗

  20

  

  2.gif

  http://zyr.yeah.net

  网络新地带

  30

  

   第一行表示当用户点击图片时,系统自动调用redi.asp程序,下面依次为广告的宽度、高度和边宽,再下面为图片的名字、链接的地址、广告说明(在html中的标记为alt=...)和显示的频度。

   redi.asp是当用户点击图片时,系统需调用的文件,它只做一个redirect的工作。内容为:

  <%response.redirect(request.querystring("url"))%>

  整个编写和维护工作都非常简单。如果你希望增加、减少或修改某些广告图片和链接地址,只需修改info.txt文本文件即可。Ad Rotator类有三个属性,Border(指定广告图片的边宽)、Clickable(指定该广告图片是否提供链接功能)、TargetFrame(指定点击超链接后的浏览页面)和一个方法GetAdvertisement(读取广告信息)。如果你采用了信息档案文本(txt),就不需要考虑Ad所提供的属性了,如前面的例子。

  

   3.File Access Component(FileSystemObject,文件存取控件)

   该控件主要用于读取Unicode或ASCII码的文件,包含的方法如下:

  ・CreateTextFile

   建立一个TextStream的对象,并指向实际操作的文本或希望建立的文件名及目录,如:

   set FILE=CREATEOBJECT("SCRIPTING.FileSystemObject")

   set F1=FILE.CreateTextFile("C:TEST.TXT",TRUE)

   ;True表示允许覆盖,False表示不允许覆盖,这里缺省了一个参数unicode,缺省和False表示建立的文件是ASCII格式,True表示文件为Unicode格式。

   F1.WRITELINE("你好!")

   F1.CLOSE

   TextStream对象具有以下方法(即上文中的F1)。

   Close:关闭对象

   Read:读取已打开的文件资料,带参数指明希望读取的字节数,如:F1.Read(characters)。

   ReadAll:读取已打开文件的全部信息(返回字符串)。

   ReadLine:读取已打开文件的一行信息(返回字符串)。

   Skip:跳过已打开的文件信息,带参数指明希望跳过的字节数,如:F1.Skip(characters)。

   SkipLine:跳过已打开文件的一行信息。

   Write:把资料写入到已打开的文件中,如:F1.Write(string)。

   WriteLine:把信息写入到已打开的文件中并换行。

   WriteBlankLine:把空行写入到已打开的文件中,带参数指明希望写入的空行数,如:F1.WriteBlankLine(lines)。

  ・OpenTextFile

  打开一个已存在的文件,并建立一个TextStream对象。

  语法:[object].OpenTextFile(filename[,iomode[,create[,format]]])

  参数说明:

   object:自定义的FileSystemObject对象名称。

   filename:希望打开的文件名称。

   iomode:可选参数为ForReading(读取)或ForAppending(编辑)。

   create:指定如果文件不存在,是否自行建立,True表示建立,False表示不建立。

   format:可选参数为TristateTrue(以Unicode方式打开)、TristateFalse(以ASCII方式打开)、TristateUseDefault(用文件缺省形式打开)和缺省时以ASCII方式打开。

  

   4.Content Linking(文件链接控件)

   该控件用于管理一些超链接信息,例如:我们经常会在html文本中有一些友情链接,指向其他站点,如果我们在多个页面上有这些信息,修改时就需要做多次修改。使用了该控件后,所有这些链接信息都可放在同一个文本文件中,修改时只需对该文本文件进行修改。其方法如下:

   GetListCount:计算URL列的总数。

   语法:GetListCount(文件名)

   GetNextURL:读取下一个URL链接地址。

   语法:GetNextURL(文件名)

   GetPreviousDescription:读取前一个URL链接的描述。

   语法:GetPreviousDescription(文件名)

   GetListIndex:获取当前资料的索引号码。

   语法:GetListIndex(文件名)

   GetNthDescription:获取当前索引号码的超链接的描述。

   语法:GetNthDescription(文件名,索引号码)

   GetPreviousURL:读取上一个URL链接地址。

   语法:GetPreviousURL(文件名)

   GetNextDescription:读取下一个URL链接的描述。

   语法:GetNextDescription(文件名)

   GetNthURL::获取当前索引号码的超链接地址。

   语法:GetNthURL(文件名,索引号码)

   调用该控件,可用下列代码:

   ...

   <% set LINK=SERVER.CREATEOBJECT("MSWC.NEXTLINK")%>

   <%COUNT=LINK.GETLISTCOUNT("LINK.TXT")%>

   <%I=1%>

   <%DO WHILE (I<=COUNT)%>

   <A HREF="<%=LINK.GETNTHURL("LINK.TXT",I)%>">

   <%= LINK.GETNTHDESCRIPTION("LINK.TXT,I)%>

  

  


   <%I=I+1%>

   <%LOOP%>

   ...

   LINK.TXT的文件格式如下:

   www.gznet.com广州视窗

   zyr.yeah.net网络新地带

  

   5.BrowserType Capabilities(浏览器相容控件)

   通过ASP的Server内嵌对象可以获取如IP地址等客户端的信息,但如要获取如客户端浏览器是否支持ActiveX控件、背景音乐等客户端浏览器的详细资料则只能求助于BrowserType控件。该控件通过把客户端的请求报头与Browscap.ini文件进行比较,得出客户端浏览器的详细资料,通过读取该控件的属性可以获取相应的资料。

   属性:

   ActiveXControls:是否支持ActiveX Controls。

   Backgroundsounds:是否支持背景音乐。

   Beta:Beta的版本。

   Browser:浏览器名称。

   Cookies:是否支持cookies。

   Frames:是否支持frame。

   Javascript:是否支持javascript。

   Platform:客户端平台。

   Tables:是否支持table。

   Vbscripts:是否支持vbscript。

   Versions:版本名称。

  

   二.如何调用用户编写的ActiveX控件

   调用一些free或用户编写的ActiveX控件是ASP一个非常重要的高级应用,下面将用一个例子具体描述其调用步骤。因特网上最常见的就是下载功能了,而上载功能却不是每个站点都能提供。上载就是通过浏览器把客户端的文件传到服务器上,该例子就是一个实现上载功能的应用。为了简单起见,这里利用一个free的ftp ActiveX控件(当然也可以自己编写)来实现该功能。该控件名称为ASPINET.FTP,可从http://www.genusa.com/asp/站点处下载。该例子含两个文件,一个用于完成客户端选取文件的功能(select.html)、一个用于完成接受信息流的功能(receive.asp)。

   1.安装该控件

   1) 解压

   2) 把DLL文件移到系统的相应目录下(如:winntsystem32 for NT),并修改系统注册表;如果不是很熟悉系统注册表的修改,可执行以下命令,系统会自动完成所有工作(你的系统需要有WinInet.dll文件)。

   regsvr32 ASPInet.DLL

   3) 运行MarkInet.exe,使注册表中所修改的信息生效。

   2.select.html

  <html>

  <body>

  <form method=post action="receive.asp">

  客户端的文件名:<input type="file" name="cfilename" >

  <br>

  上载到服务器后的文件名:<input type="text" name="sfilename" >

  ;你可通过网页输入希望上载到服务器上的文件名称

  <br>

  <input type="submit" name="submit" value="确定“>

  </form>

  </body>

  </html>

   3.receive.asp

  <%

  cfilename=request("cfilename")

  ;读取客户端的文件名及路径

  sfilename=request("sfilename")

  ;读取希望上载到服务器上的文件名

  FTP_TRANSFER_TYPE_ASCII = 1

  FTP_TRANSFER_TYPE_BINARY = 2

  set ftpconn=SERVER.CREATEOBJECT("AspInet.FTP")

  ;创建ftp ActiveX控件对象

  if FtpConn.FTPPutFile("Ftp服务器地址“,"anonymous", "user@hostname.net",sfilename,cfilename,FTP_TRANSFER_TYPE_BINARY) then

  ;参数说明:依次为Ftp服务器地址、使用者名字、密码、Server端文件名及路径(相对于Ftp根目录而言,该例子使用缺省目录,即Ftp根目录)、客户端的文件名及路径、传送类型(ASCII/Binary)

   Response.Write "<p>FTP upload Success...<br>"

  else

   Response.Write "<p>FTP upload Failed...<br>"

  end if

  %>

   如果你已经熟练地掌握了ASP各内嵌对象,包括ActiveX控件的使用方法,则一般的应用对于你来说已不是难事。但要提高开发效率,则必须充分利用微软提供的ASP开发工具InterDev配合开发。
-= 资 源 教 程 =-
文 章 搜 索
关键词:
类型:
范围:
纯粹空间 softpure.com
Copyright © 2006-2008 暖阳制作 版权所有
QQ: 15242663 (拒绝闲聊)  Email: faisun@sina.com
 纯粹空间 - 韩国酷站|酷站欣赏|教程大全|资源下载|免费博客|美女壁纸|设计素材|技术论坛   Valid XHTML 1.0 Transitional
百度搜索 谷歌搜索 Alexa搜索 | 粤ICP备19116064号-1