Server 对象用于处理服务器上的一些特殊任务,例如,创建组件实例、获取文件路径、执行ASP脚本文件等。
Server 对象是体现 ASP 强大功能的一个对象,之前介绍的对象都是针对获取、请求以及简单存储信息而设计的,之所以说它强大,有两个原因,第一可以通过 Server 对象创建服务器上所具有的组件的实例,从而扩展 ASP 功能;第二 Server 对象可以执行服务器上的 ASP 文件,从而使得一些大型系统的架构变得简单。
Server 的属性
Server 对象只有一个属性 ScriptTimeout,设置或返回当前页面执行的超时时间(秒)。
设定完毕后,当当前页面在服务器上的执行时间超过这个时间,则会强制终止当前页面的运行。因此如果某个页面可能运行时间较长的话,就需要手动来增大这个值,来保证页面可以正常执行完毕。
下面的例子(Server_ScriptTimeout.asp)演示如何设置及取回 ScriptTimeout 值,主要代码如下:
<h3>如果不设定ScriptTimeout属性,IIS中默认值为 <%=Server.ScriptTimeout%> 秒</h3>
<h3>手动属性设置为200秒,现在值为 <%=Server.ScriptTimeout%> 秒</h3>
显示结果如下,IIS默认的 ScriptTimeout 属性值为 90 秒。
Server 的方法
方法 | 描述 |
CreateObject(progID) | 创建由 progID 标识的对象的一个实例 |
Execute(path) | 停止当前页面的执行,把控制转到 path 中指定的网页。在该页面执行完毕后,控制传递回原先的页面,并继续执行 Execute 后面的语句。 |
GetLastError() | 返回 ASPError 对象,描述发生错误的原因 |
HTMLEncode(string) | 对字符串进行 HTML 转义 |
MapPath(path) | 返回在 Path 中指定的文件或资源的完整物理路径和文件名 |
Transfer(path) | 停止当前页面的执行,把控制转到 path 中指定的页面 |
URLEncode(string) | 对字符串进行 URL 转义 |
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 方法是在另外一个页面执行完毕后即停止运行了。
我们下面的例子将说明 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 后,效果如下:
Response.Redirect 和 Server.Transfer 方法比较
首先两者都是将页面的控制权转移到另外的页面进行处理。但是还是有不同的地方。
1、Redirect 方法是在HTTP头中输出代码,让浏览器重新请求要转向的目标页面,而 Server.Transfer 方法则是在服务器上直接将当前的控制权转给目标页面,在客户端并不会意识到当前的页面已经发生了变化。
2、Redirect 方法可以重定向到任何的 URL,而 Transfer 方法是在服务器上转移控制权,因此只可以 Transfer 到本地服务器存在的页面。
3、在使用 Transfer 方法时,会将当前页面的事务以及 Request 各个集合相应传递到目标页面,而 Redirect 方法仅仅是通知浏览器开启一个新的请求。
URLEncode 和 HTMLEncode 方法
两者都是对某个字符串进行转义的操作。
下面的代码(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 中运行后,返回了服务器上的完整路径,如下: