当前位置:中国站长下载文章中心网页编程ASP编程 → 在ASP中操作HTTP报头方法分析(2)

在ASP中操作HTTP报头方法分析(2)

减小字体 增大字体 作者:不详  来源:不详  发布时间:2006-8-13 0:39:47
     3. MIME类型和内容类型
  
    当我们想向浏览器发送一个动态创建的字符串,而且它们自己提供给浏览器时没有直接指明内容类型,而是提供表示是否是磁盘文件的扩展名时,Response.ContentType是非常有用的。除非特别指定,所有ASP创建的网页缺省都为“text/type”。内容类型的标识符是MIME类型(MIME代表Multi-purpose Internet Multimedia Extension或Multi-pupose Internet Mail Extension,通常依据上下文来定)。
  
    例如,若发送到客户的数据注解是通过从数据库读二进制值创建的图片,就需要在发送任何内容之前添加合适的CONTENT-TYPE报头:
  
  Response.ContentType = “image/jpeg”
  
    假如从一个数据库创建一个XML文件,使用MIEM类型“text/xml”;并且如果正在创建一个文本文件可以在文件编辑器中显示或作为一个磁盘文件在客户上被存储起来,使用“text/text”。
  
    4. 添加PICS卷标
  
    Respnse.Pics属性仅仅是添加一个PICS(Platform for Internet Content system)卷标到页面上,方式与通常用<META>标记所用的方式相同:
  
  QUOT = Chr(34)
  StrPicsLabel = “(PICS-1.0” & QUOT & “http://www.rsac.org/ratingsv01.html”_
  & QUOT & “ 1 gen true comment “ & QUOT _
  & “RSACi North America Server” & QUOT & “ for “ & QUOT _
  & “http://yoursite.com” & QUOT & “ on “ & QUOT _
  & “1999.08.01T03:04-0500” & QUOT & “ r (n 0 s 0 v 2 l 3))”
  Response.Pics(strPicsLabel)
  
    这段代码添加了如下的PICS卷标:
  
  (PICS-1.0 “http://www.rsac.org/ratingsv01.html” 1 gen true comment “RSACi
  North America Server” for “http://yoursite.com” on “1999.08.01T03:04-0500”
  r (n 0 s 0 v 2 l 3))
  
    要得到关于PICS的更多的信息,或了解更多的定义页面内容的方式,请检索http://www.rsac.org/站点。
  
    在Internet Service Manager中定义报头
  
    在本系列文章的第一部分,已经说明了如何在Internet Service Manage(MMC插件)应用程序中设置每个Web网站和IIS 5.0目录的属性,这就定义了使用此站点或目录资源发送到客户机的所有请求的HTTP报头,也就提供了使用每个网页中的ASP脚本代码设置这些属性的替代方法。
  
    在Web站点或目录上右击鼠标并选择“Properties”,在其对话框的“HTTP Headers”选项卡中,可设置页面内容有效期的相对时间或绝对日期,定义定制的报头,创建PICS内容等级标签,也可以通过MIME类型映射来定义内容类型。
  
    那么可以看到已创建了自定义的REFRESH HTTP报头,应用于从此目录载入的所有网页。即每一分钟自动地重载(刷新)一次(对于显示棒球比赛的最近比分是非常理想的,但对服务器而言负担太重了)。
  
    要在“MIME Map”框中添加自定义的内容类型映射,只需在“Properties”主对话框中单击“File Types”按扭把它们添加到清单中即可。
  
    当使用HTTP报头开始试验时,你很快会发现不是所有的浏览器表现都相同,许多浏览器以不同的方式响应不同的HTTP报头,使得可靠地建立一个普遍适用的原则有时极为困难。
  
    2. 使用客户证书
  
    假如设立了一个安全的Web网站或部分内容具有安全机制的网站,可安装一个数字服务器证书,通过允许访问者使用证书中的加密的细节,来验证服务器。每一次对该站点或目录的页面请求,服务器都将发送证书的一个副本,浏览器可检查这个副本以确定正在和谁交谈。
  同样,也可设置服务器,要求用户在进入网站时提供一个有效的数字证书。他们可从很多来源获得此证书,例如Verisign(http://www.verisign.com)或Thawte Consulting(http://www.thawte.com)。读者将在第25章看到这一处理过程的细节。
  
    这些情况都使用了Request对象的ClientCertificate集合的值,本章的实例代码中,已包含了一个显示用户如何使用些集合值的一些方法的页面。
  
    这一网页被命名为showcert.asp,而且其所做的一切就是遍历ClientCertificate集合显示其包含的所有值。可使用以前经常使用的简单代码来完成它,唯一的不同之处就是建立一个HTML表以容纳结果,并将其截为每60个字符一组。
  
  <TABEL CELLPADDING=0 CELLSPACING=0>
  <%
  For Each keyItem In Request.ClientCertificate()
   StrItemValue = Request.ClientCertificate(keyItem)
   If Len(strItemValue) > 90 Then strItemValue = Left(strItemValue, 60) & “..etc.”
   Response.Write “<TR><TD>” & keyItem & “ = “ & strItemValue & “</TD></TR>”
  Next
  %>
  </TABLE>
  
    使用客户证书重定向
  
    一旦要求所有访问网站或部分网站的浏览者给出的其客户证书,就可以使用其包含的信息来制作我们为此用户创建的网页。例如,可使用他们的证书的Organization条目来自动使他们重定向到该网站的指定部分,使别的访问者重定向到别的地方:
  
  If Request.ClientCertificate(“SubjectO”) = “Wrox Press Inc” Then
   Response.Redirect “/wrox_staff/default.asp” ‘Wrox staff site
  Else
   Response.Redirect “/public/Default.asp” ‘Normal public site
  End If
  
    相应地,可使用Country条目来使访问者重定向到一个相应的网站:
  
  Select Case Request.ClientCertificate(“SubjectC”)
   Case “UK”: Response.Redirect “http://uk_site.co.uk/”
   Case “DE”: Response.Redirect “http://de_site.co.de/”
   Case “FR”: Response.Redirect “http://fr_site.co.fr/”
   ‘... ect.
   Case Else: Response.Redirect “http://us_site.com/”
  End Select
  
    3. 读写二进制数据
  
    有两个方法提供了对从浏览器发送到服务器的HTTP数据流和从服务器返回到浏览器的数据流的二进制数据访问。Request.BinaryRead方法可得到指定要读取的字节数的参数,并返回变体类型的数组,其中包含从请求的POST段中得到的字节(例如在ASP的Form集合中数据)。下面的程序读数据的头64个字节:
  
  varContent = Request.BinaryRead(64)
  
    假如使用了BinaryRead方法,以后就不能访问ASP的Request.Form集合。同样,一旦我们采用任何方式引用了Request.Form集合,就不能使用BinaryRead方法。
  
    把二进制数据写进ASP创建的响应流中也是可能的,可采用BinaryWrite方法。需要给其提供想写到客户的字节的变

[1] [2]  下一页