ADO 简介 在 ASP 中访问数据库使用的 ADO 组件。 ADO 是一项微软的技术。 ADO 指 ActiveX 数据对象(ActiveX Data Objects)。
顺晟科技
2021-07-06 17:27:07
336
Server 对象用于处理服务器上的一些特殊任务,例如,创建组件实例、获取文件路径、执行ASP脚本文件等。
Server 对象是体现 ASP 强大功能的一个对象,之前介绍的对象都是针对获取、请求以及简单存储信息而设计的,之所以说它强大,有两个原因,可以通过 Server 对象创建服务器上所具有的组件的实例,从而扩展 ASP 功能;第二 Server 对象可以执行服务器上的 ASP 文件,从而使得一些大型系统的架构变得简单。
Server 对象只有一个属性 ScriptTimeout,设置或返回当前页面执行的超时时间(秒)。
设定完毕后,当当前页面在服务器上的执行时间超过这个时间,则会强制终止当前页面的运行。因此如果某个页面可能运行时间较长的话,就需要手动来增大这个值,来保证页面可以正常执行完毕。
下面的例子(Server_ScriptTimeout.asp)演示如何设置及取回 ScriptTimeout 值,主要代码如下:
<h3>如果不设定ScriptTimeout属性,IIS中默认值为 <%=Server.ScriptTimeout%> 秒</h3> <h3>手动属性设置为200秒,现在值为 <%=Server.ScriptTimeout%> 秒</h3>
显示结果如下,IIS默认的 ScriptTimeout 属性值为 90 秒。
CreateObject 方法,用于创建服务器上的组件的实例。最常用的就是创建数据库操作组件的ADO的实例,我们手头刚刚创建了一个 Access 数据库 ServerInfo.accdb,这个数据库有一个名为 ServerMethods 的表,表里面记录了 Server 对象的方法(Method 字段)及描述信息(Description 字段),如下图:
我们的例子(Server_CreateObject.asp)主要是读取出表的全部内容,部分代码如下:
<% Dim oConn, sConnString, sDBPath, oRs, sql '数据库文件名 sDBPath = "ServerInfo.accdb" '数据连接字符串 sConnString = "Provider=Microsoft.ACE.OLEDB.15.0;Data Source=" & Server.MapPath(sDBPath) '创建 Connection 对象的实例 oConn Set oConn = Server.CreateObject("ADODB.Connection") '调用 oConn 的 Open 方法来打开连接 oConn.Open sConnString 'SQL语句,查询所有记录 sql = "SELECT * FROM ServerMethods" '建立 ADODB.RecordSet 对象实例 oRs Set oRs = Server.CreateObject("ADODB.RecordSet") '通过SQL语句获得记录集 oRs.Open sql, oConn Do While Not oRs.EOF Response.Write("<tr>") Response.Write("<td>" & oRs("Method") & "</td>") Response.write("<td>" & oRs("Description") & "</td>") Response.Write("</tr>") oRs.MoveNext Loop oRs.Close Set oRs = Nothing oConn.Close Set oConn = Nothing %>
运行效果如下:
在这段代码中我们用到了两次 CreateObject,如下代码:
... '创建 Connection 对象的实例 oCon Set oConn = Server.CreateObject("ADODB.Connection") ... '建立 ADODB.RecordSet 对象实例 oRs Set oRs = Server.CreateObject("ADODB.RecordSet") ...
在后面的介绍会详细介绍数据库方面的知识。
两者的作用都是停止当前页面的运行,并传递到另外一个一面,其不同在于,Execute 方法是在另外一个页面执行完毕后回到现在的页面继续向下执行,而 Transfer 方法是在另外一个页面执行完毕后即停止运行了。
我们下面的例子将说明 Execute 和 Transfer 方法的区别,我们 建立两个 ASP 文件(File1.asp 和 File2.asp)
File1.asp 代码如下:
... <h3>Server.Execute演示</h3> <% Response.Write("I am in File 1!<br>") Server.Execute("File2.asp") Response.Write("I am back in File 1!") %> <hr> <h3>Server.Transfer演示</h3> <% Response.Write("I am in File 1!<br>") Server.Transfer("File2.asp") Response.Write("I am back in File 1!") %> ...
File2.asp 代码如下:
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%> <% Response.Write("I am in File 2!<br>") %>
执行 File1.asp 后,效果如下:
首先两者都是将页面的控制权转移到另外的页面进行处理。但是还是有不同的地方。
1、Redirect 方法是在HTTP头中输出代码,让浏览器重新请求要转向的目标页面,而 Server.Transfer 方法则是在服务器上直接将当前的控制权转给目标页面,在客户端并不会意识到当前的页面已经发生了变化。
2、Redirect 方法可以重定向到任何的 URL,而 Transfer 方法是在服务器上转移控制权,因此只可以 Transfer 到本地服务器存在的页面。
3、在使用 Transfer 方法时,会将当前页面的事务以及 Request 各个集合相应传递到目标页面,而 Redirect 方法仅仅是通知浏览器开启一个新的请求。
两者都是对某个字符串进行转义的操作。
下面的代码(ServerEncode.asp)展示了两个转义方法的区别和效果:
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%> <!doctype html> <html> <head> <meta charset="utf-8"> <title>HTMLEncode 和 URLEncode 的应用</title> </head> <body> <p> <% Response.write(Server.HTMLEncode("The image tag: <img>")) %> </p> <p> <% Response.Write(Server.URLEncode("http://www.baidu.com")) %> </p> </body> </html>在 Firefox 中运行效果如下:
在 Firefox 中“查看页面源代码”中我们发现 “<img>” 之所以能正常显示,而不被识别成 HTML 标签,是将 “<”符号转义为”<“,将”>”符号转义为”>“。
而 URLEncode 则是把空格转化为+号,非字母数字符号转义为十六进制表示。
MapPath 方法
在上面的 CreateObject 方法讲解中,有一条语句用到了 MapPath 方法,代码如下:
'数据库文件名 sDBPath = "ServerInfo.accdb" '数据连接字符串 sConnString = "Provider=Microsoft.ACE.OLEDB.15.0;Data Source=" & Server.MapPath(sDBPath)
此方法用户获得服务器上指定文件在服务器上的物理路径。例如上面提到的 ServerInfo.accdb 的路径是啥?
我们通过实例(ServerMapPath.asp)展示,主要代码如下:
<%=Server.MapPath("ServerInfo.accdb")%>
在 Firefox 中运行后,返回了服务器上的完整路径,如下:
Server.rar
06
2021-07
06
2021-07
06
2021-07
06
2021-07
06
2021-07
06
2021-07