ASP Browser Capabilities 组件

实例

Browser Capabilities 组件

本例演示如何测定每一个访问网站的浏览器的类型、性能以及版本号。

  1. <html>
  2. <body>
  3. <%
  4. Set MyBrow=Server.CreateObject("MSWC.BrowserType")
  5. %>
  6. <table border="1" width="65%">
  7. <tr>
  8. <td width="52%">客户机操作系统</td>
  9. <td width="48%"><%=MyBrow.platform%></td>
  10. </tr>
  11. <tr>
  12. <td >Web 浏览器</td>
  13. <td ><%=MyBrow.browser%></td>
  14. </tr>
  15. <tr>
  16. <td>浏览器版本</td>
  17. <td><%=MyBrow.version%></td>
  18. </tr>
  19. <tr>
  20. <td>框架支持</td>
  21. <td><%=MyBrow.frames%></td>
  22. </tr>
  23. <tr>
  24. <td>表格支持</td>
  25. <td><%=MyBrow.tables%></td>
  26. </tr>
  27. <tr>
  28. <td>音频支持</td>
  29. <td><%=MyBrow.backgroundsounds%></td>
  30. </tr>
  31. <tr>
  32. <td>Cookies 支持</td>
  33. <td><%=MyBrow.cookies%></td>
  34. </tr>
  35. <tr>
  36. <td>VBScript 支持</td>
  37. <td><%=MyBrow.vbscript%></td>
  38. </tr>
  39. <tr>
  40. <td>JavaScript 支持</td>
  41. <td><%=MyBrow.javascript%></td>
  42. </tr>
  43. </table>
  44. </body>
  45. </html>

ASP Browser Capabilities 组件

ASP Browser Capabilities 组件会创建一个 BrowserType 对象,这个对象可测定访问者浏览器的类型、性能以及版本号。

当浏览器连接到服务器时,就会向服务器发送一个 HTTP User Agent 报头。这个报头包含着有关浏览器的信息(比如浏览器类型和版本号)。BrowserType 对象会把报头中的信息与服务器上名为 "Browscap.ini" 的文件中的信息作比较。

如果标题中被发送的浏览器类型和版本号和 "Browsercap.ini" 文件中信息可以匹配,那么我们就可以使用 BrowserType 对象列出这个匹配的浏览器的相关属性。如果上述情况不匹配,这个对象会把每个属性设置为 "UNKNOWN"。

语法

  1. <%
  2. Set MyBrow=Server.CreateObject("MSWC.BrowserType")
  3. %>

下面的例子对在 ASP 文件中创建一个 BrowserType 对象,并显示一个展示当前浏览器性能的表格:

  1. <html>
  2. <body>
  3.  
  4. <%
  5. Set MyBrow=Server.CreateObject("MSWC.BrowserType")
  6. %>
  7.  
  8. <table border="1" width="100%">
  9. <tr>
  10. <th>Client OS</th>
  11. <th><%=MyBrow.platform%></th>
  12. </tr><tr>
  13. <td >Web Browser</td>
  14. <td ><%=MyBrow.browser%></td>
  15. </tr><tr>
  16. <td>Browser version</td>
  17. <td><%=MyBrow.version%></td>
  18. </tr><tr>
  19. <td>Frame support?</td>
  20. <td><%=MyBrow.frames%></td>
  21. </tr><tr>
  22. <td>Table support?</td>
  23. <td><%=MyBrow.tables%></td>
  24. </tr><tr>
  25. <td>Sound support?</td>
  26. <td><%=MyBrow.backgroundsounds%></td>
  27. </tr><tr>
  28. <td>Cookies support?</td>
  29. <td><%=MyBrow.cookies%></td>
  30. </tr><tr>
  31. <td>VBScript support?</td>
  32. <td><%=MyBrow.vbscript%></td>
  33. </tr><tr>
  34. <td>JavaScript support?</td>
  35. <td><%=MyBrow.javascript%></td>
  36. </tr>
  37. </table>
  38.  
  39. </body>
  40. </html>

输出:

Client OS WinNT
Web Browser IE
Browser version 5.0
Frame support? True
Table support? True
Sound support? True
Cookies support? True
VBScript support? True
JavaScript support? True

Browscap.ini文件

"Browsercap.ini" 文件用于声明属性,并设置各浏览器的默认值。

本节内容不是关于如何 Browscap.ini 文件的教程,我们只提供一些关于 "Browsercap.ini" 的基础知识和概念。

"Browsercap.ini" 文件可包含下面的信息:

  1. [;comments]
  2. [HTTPUserAgentHeader]
  3. [parent=browserDefinition]
  4. [property1=value1]
  5. [propertyN=valueN]
  6. [Default Browser Capability Settings]
  7. [defaultProperty1=defaultValue1]
  8. [defaultPropertyN=defaultValueN]
参数 描述
comments 可选项。任何起始于分号的代码行都被 BrowserType 对象忽略
HTTPUserAgentHeader 可选项。规定与在 propertyN 中设定的 browser-property 值声明相关的 HTTP User Agent 报头。允许使用通配符。
browserDefinition 可选项。规定作为父浏览器使用的某个浏览器的 HTTP User Agent header-string。当前浏览器的定义会继承在父浏览器的定义中所有声明过的属性值。
propertyN 可选项。规定浏览器的属性。下面的表格列出了某些可能的属性: - ActiveXControls - 是否支持ActiveX控件? - Backgroundsounds - 是否支持背景声音? - Cdf - 是否支持针对网络广播(Webcasting)的频道定义格式(Channel Definition Format)? - Tables - 是否支持表格? - Cookies - 是否支持cookies? - Frames - 是否支持框架? - Javaapplets - 是否支持Java applets? - Javascript - 是否支持JScript? - Vbscript - 是否支持VBScript? - Browser - 定义浏览器的名称 - Beta - 浏览器是否为beta软件? - Platform - 规定浏览器运行的平台 - Version - 规定浏览器的版本号。
valueN 可选项。规定 propertyN 的值。可为字符串、整数(前缀为#)或者逻辑值。
defaultPropertyN 可选项。规定浏览器属性的名称,假如已定义的 HTTPUserAgentHeader 值中没有值能与浏览器发送的 HTTP 用户代理报头相匹配,则为这个属性分配一个默认的值。
defaultValueN Optional. 规定 defaultPropertyN 的值。可为字符串、整数(前缀为 #)或者逻辑值。

"Browsercap.ini"文件会类似这样:

  1. ;IE 5.0
  2. [IE 5.0]
  3. browser=IE
  4. Version=5.0
  5. majorver=#5
  6. minorver=#0
  7. frames=TRUE
  8. tables=TRUE
  9. cookies=TRUE
  10. backgroundsounds=TRUE
  11. vbscript=TRUE
  12. javascript=TRUE
  13. javaapplets=TRUE
  14. ActiveXControls=TRUE
  15. beta=False;DEFAULT BROWSER
  16. [*]
  17. browser=Default
  18. frames=FALSE
  19. tables=TRUE
  20. cookies=FALSE
  21. backgroundsounds=FALSE
  22. vbscript=FALSE
  23. javascript=FALSE