我们已经在几处见到asp如何创建或修改在响应页面请示时被发送到客户的http报头。在response对象中有几个属性和方法可帮助我们做到一点。下面是一些报头方法:
· 控制缓存和有效期。
· 创建状态和定制的http报头。
· 指定mime类型或内容类型。
· 添加pics标签。
接下来将简要地研究每一个方面。可在“response object”主页(show_response.asp)上,单击相关属性名或方法名,来检查我们所说的属性和方法。
1. 缓存和“到期”asp网页
用户的浏览器以及他们和服务器这间的任一代理服务器,都可以缓存html和用asp创建的网页。当用户随后请求页面时,浏览器就发送一个“最新修改”的请求到服务器(使用一个包含缓存版本的日期的http_if_modified_since报头),询问网页是否已被修改。
若没有被修改,服务器应用状态码和消息“304 not modified”来响应,浏览器将使用缓存的内容而不会通过网络下载一个副本。若已经存在已修改的版本,它就会与“200 ok”状态码和消息一道被发送出去。
1) response.cachecontol属性
其他的一些因素也会影响这一处理过程。然而,任一被网页使用的网络路由内的代理服务器(一般位于客户机端),能被通过设置response.cachecontrol属性为private来放弃缓存网页。在asp 3.0中对asp网页这是缺省的,不用设置。但在网页为个别访问者特别定制时尤其有用。这可以阻止别的在同一网络上的用户进入同一网页。当cachecontrol的属性值被设定为public时,允许服务器缓存网页。注意,一些代理服务器可能表现得不尽相同,或忽视或越过这个报头。
在ie4中,在代理服务器缓存可用时,有可能得到一个虚假的“this page has expired”消息。我们已提供了一个网页(expiretest_form.asp),可以通过自己的代理服务器在网络上做试验,来检查这一属性的影响。可以通过在“response object”主页中单击“response. cachecontrol”链接来显示这个网页。如下图所示:
这一页面提交到expiretest_result.asp网页时,能够设置response.cachecontrol属性,然后在网页中插入值和脚本被执行的时间:
<%
if request.form(“public”) = “on” then ‘cache-control check box was ticked
response.cachecontrol = “public”
else
response.cachecontrol = “private”
end if
%>
<html>
...
cache-control is: <b><% = response.cachecontrol %></b><p>
value in text box is: <b><% response.write request.form(“textbox”) %>
<%
response.write right(“0” & hour(now),2) & “:” & right(“0” & minute(now),_
& 2) & “:” & right(“0” & second(now),2)
%></b>
通过单击浏览器上的“back”和“forward”,能看到代码是自动执行还是使用缓存的副本。
2) response.expires和response.expiresabsolute属性
控制缓存的网页存放时间的两个属性为response对象的expires和expriesabsolute属性。response.expires定义了风页在从缓存区被丢弃前应保持有效的时间长度,以创建以来的分钟数形式表示。expiresabsolute属性为到期时间设置了一个绝对的日期和时间。
我们提供一个命名为addheaders_form.asp的例子网页,用于演示如何使用这些属性。在“response object”主页中单击对这两种属性的链接。
在得到的页面中,可加入自己定制的http报头,并可设置一些影响响应的http报头的多种属性。在“提交查询内容”按钮上单击时,页面show_headers.asp在返回的数据流中添加所选的报头,然后显示用来完成此操作的代码,显示相应的执行时间,可用来检查页面是被缓存还是被再次执行。
show_headers.asp网页中的代码创建和添加http报头,程序如下:
<%
‘write http headers before any other output
if request.form(“expires”) = “on” then _
response.expires = request.form(“expires_value”)
if request.form(“expiresabs”) = “on” then _
response.expiresabsolute = request.form(“expiresabs_value”)
if request.form(“lastmod”) = “on” then _
response.addheader “last-modified”, cstr(request.form(“lastmod_value”))
if request.form(“pragma”) = “on” then _
response.addheader “pragma”, cstr(request.form(“pragma_value”))
if request.form(“refresh”) = “on” then _
response.addheader “refresh”, cstr(request.form(“refresh_value”))
if request.form(“addheader”) = “on” and len(request.form(“addheader_name”)) then _
response.addheader cstr(request.form(“addheader_name”)), _
cstr(request.form(“addheader_value”))
if request.form(“status”) = “on” then _
response.status = request.form(“status_value”)
%>
<html>
...
... show code and execution time
...
其余部分仅仅是显示已被执行的代码和执行时间。读者会注意到包含在网页中的定制的报头“pragma”(至今我们还没讨论过)。一些(先前的)代理服务器使用它作为网磁是否应被缓存的指示。缺省是网页被缓冲,除非接受到http报头“pragma=no-cache“。
2. 创建状态码和定制的http报头
可使用先前在实例网页中所看到的response对象的addheader方法来创建自己的状态码或自己喜欢的定制的报头。这一方法需要两个参数:http报头名称或一个包含其值或分配给它的值的字符串。作为一个例子,下面的代码在页面中添加refresh报头:
response.addheader “refresh”, ”60;url=newpath/newpage.asp”
这等同于客户机端<meta>元素:
<meta http-equiv=”refresh”, “60;url=newpath/newpage.asp”>
换句话说,也可配合status属性使用addheader方法使浏览器载入一个新的页面:
response.status = “302 object moved”
response.addheader “location”, “newpath/newpage.asp”
这等同于使用response.redirect方法:
response.redirect “newpath/newpage.asp”
response.status属性可被用来发送一些所需要的状态消息,例如添加如下几行:
response.status= “401 unauthorized”
response.addheader “www-authenticate”, “basic”
强制浏览器显示一个用户名/口令对话框,然后使用basic验证把它们发送回服务器(将在本系列后续部分看到验证方法)。
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器