user_agent.html 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
  6. <title>User-Agent 类 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
  7. <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
  8. <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
  9. <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
  10. <link rel="canonical" href="http://codeigniter.org.cn/user_guide/libraries/user_agent.html" />
  11. <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
  12. <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
  13. <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
  14. <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
  15. <meta name="robots" content="all" />
  16. <meta name="author" content="ExpressionEngine Dev Team" />
  17. <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
  18. </head>
  19. <body>
  20. <!-- START NAVIGATION -->
  21. <div id="nav">
  22. <div id="nav_inner">
  23. <script type="text/javascript">create_menu('../');</script>
  24. </div>
  25. </div>
  26. <script type="text/javascript">_setNavigation();</script>
  27. <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="切换目录" alt="切换目录" /></a></div>
  28. <div id="masthead" class="clearfix">
  29. <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
  30. <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a>  <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
  31. </div>
  32. <!-- END NAVIGATION -->
  33. <!-- START BREADCRUMB -->
  34. <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
  35. <tr>
  36. <td id="breadcrumb">
  37. <a href="#" target="_blank">CodeIgniter 中国首页</a>&nbsp;&#8250;&nbsp;
  38. <a href="../index.html">用户指南首页</a>&nbsp;&#8250;&nbsp;User-Agent 类 </td>
  39. <td id="searchbox">
  40. <form method="get" action="http://www.google.com.hk/search" target="google_window">
  41. <input type="hidden" name="client" value="pub-0176846097796333"></input>
  42. <input type="hidden" name="forid" value="1"></input>
  43. <input type="hidden" name="ie" value="UTF-8"></input>
  44. <input type="hidden" name="oe" value="UTF-8"></input>
  45. <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
  46. 搜索用户指南&nbsp;
  47. <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
  48. &nbsp;
  49. <input type="submit" class="submit" name="sa" value="Go" />
  50. </form>
  51. </td>
  52. </tr>
  53. </table>
  54. <!-- END BREADCRUMB -->
  55. <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
  56. <a href="#" target="_blank">查看原文</a>
  57. </div>
  58. <!--<br clear="all" />--><!-- START CONTENT -->
  59. <div id="content">
  60. <h1>User-Agent 类</h1>
  61. <p>用户代理类提供的功能是,帮助识别是浏览器,还是移动设备或是机器人访问你的站点。另外,你可以得到referrer信息(译注:referrer信息就是访客来源信息,可以参照一般的统计系统来理解),以及语言,和支持的字符集信息。</p>
  62. <h2>初始化类</h2>
  63. <p>和大多数其他CI类一样,User Agent类也是在你的控制器里使用<dfn>$this-&gt;load-&gt;library</dfn> 方法完成初始化工作</p>
  64. <code>$this-&gt;load-&gt;library('user_agent');</code>
  65. <p>一旦加载, 对象就可以使用了: <dfn>$this-&gt;agent</dfn></p>
  66. <h2>用户代理定义</h2>
  67. <p>用户代理名称的定义,位于一个配置文件: <dfn>application/config/user_agents.php</dfn>. 如果你需要你可以添加项目到user agent数组</p>
  68. <h2>示例</h2>
  69. <p>当User Agent 类初始化后,它会判断浏览你的网站是Web浏览器,还是移动设备,还是机器人。它还收集相关的操作系统信息</p>
  70. <code>
  71. $this-&gt;load-&gt;library('user_agent');<br />
  72. <br />
  73. if ($this-&gt;agent-&gt;is_browser())<br />
  74. &#123;<br />
  75. &nbsp;&nbsp;&nbsp;&nbsp;$agent = $this-&gt;agent-&gt;browser().' '.$this-&gt;agent-&gt;version();<br />
  76. &#125;<br />
  77. elseif ($this-&gt;agent-&gt;is_robot())<br />
  78. &#123;<br />
  79. &nbsp;&nbsp;&nbsp;&nbsp;$agent = $this-&gt;agent-&gt;robot();<br />
  80. &#125;<br />
  81. elseif ($this-&gt;agent-&gt;is_mobile())<br />
  82. &#123;<br />
  83. &nbsp;&nbsp;&nbsp;&nbsp;$agent = $this-&gt;agent-&gt;mobile();<br />
  84. &#125;<br />
  85. else<br />
  86. &#123;<br />
  87. &nbsp;&nbsp;&nbsp;&nbsp;$agent = 'Unidentified User Agent';<br />
  88. &#125;<br />
  89. <br />
  90. echo $agent;<br />
  91. <br />
  92. echo $this-&gt;agent-&gt;platform(); // Platform info (Windows, Linux, Mac, etc.)
  93. </code>
  94. <h1>函数参考</h1>
  95. <h2>$this-&gt;agent-&gt;is_browser()</h2>
  96. <p>根据用户代理是否是一个已知的web浏览器,返回 TRUE/FALSE (boolean)</p>
  97. <code> if ($this-&gt;agent-&gt;is_browser('Safari'))<br />
  98. &#123;<br />
  99. &nbsp;&nbsp;&nbsp;&nbsp;echo 'You are using Safari.';<br />
  100. &#125;<br />
  101. else if ($this-&gt;agent-&gt;is_browser())<br />
  102. &#123;<br />
  103. &nbsp;&nbsp;&nbsp;&nbsp;echo 'You are using a browser.';<br />
  104. &#125;</code>
  105. <p class="important"><strong>Note:</strong>&nbsp; The string "Safari" in this example is an array key in the list of browser definitions.
  106. You can find this list in <dfn>application/config/user_agents.php</dfn> if you want to add new browsers or change the stings.</p>
  107. <h2>$this-&gt;agent-&gt;is_mobile()</h2>
  108. <p>根据用户代理是否是一个已知的移动设备,返回 TRUE/FALSE (boolean) </p>
  109. <code> if ($this-&gt;agent-&gt;is_mobile('iphone'))<br />
  110. &#123;<br />
  111. &nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('iphone/home');<br />
  112. &#125;<br />
  113. else if ($this-&gt;agent-&gt;is_mobile())<br />
  114. &#123;<br />
  115. &nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('mobile/home');<br />
  116. &#125;<br/>
  117. else<br />
  118. &#123;<br />
  119. &nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('web/home');<br />
  120. &#125;</code>
  121. <h2>$this-&gt;agent-&gt;is_robot()</h2>
  122. <p>根据用户代理是否是机器人,返回 TRUE/FALSE (boolean)</p>
  123. <p class="important"><strong>注意:</strong>&nbsp; 用户代理类仅包含了最常见的机器人定义。它不是一个完整的机器人清单。如果你觉得有些经常访问你的网站的机器人不在名单中,你可以将它们添加到你的<dfn>application/config/user_agents.php</dfn> 文件中.</p>
  124. <h2>$this-&gt;agent-&gt;is_referral()</h2>
  125. <p>根据用户代理是否是从另一网站链接过来,返回 TRUE/FALSE (boolean) </p>
  126. <h2>$this-&gt;agent-&gt;browser()</h2>
  127. <p>返回一个字符串,就是浏览你的网站的浏览器名称</p>
  128. <h2>$this-&gt;agent-&gt;version()</h2>
  129. <p>返回浏览器的版本号</p>
  130. <h2>$this-&gt;agent-&gt;mobile()</h2>
  131. <p>返回访问你的站点的移动设备名称</p>
  132. <h2>$this-&gt;agent-&gt;robot()</h2>
  133. <p>返回访问你的站点的机器人名称</p>
  134. <h2>$this-&gt;agent-&gt;platform()</h2>
  135. <p>返回访问你的站点的操作系统(Linux, Windows, OS X, 等等).</p>
  136. <h2>$this-&gt;agent-&gt;referrer()</h2>
  137. <p>如果用户代理是从其他站点链接过来的,你可以做如下判断</p>
  138. <code> if ($this-&gt;agent-&gt;is_referral())<br />
  139. &#123;<br />
  140. &nbsp;&nbsp;&nbsp;&nbsp;echo $this-&gt;agent-&gt;referrer();<br />
  141. &#125;</code>
  142. <h2>$this-&gt;agent-&gt;agent_string()</h2>
  143. <p>返回一个字符串包含所有用户代理信息。通常它会是这样的:</p>
  144. <code>Mozilla/5.0 (Macintosh; U; Intel Mac OS X; en-US; rv:1.8.0.4) Gecko/20060613 Camino/1.0.2</code>
  145. <h2>$this-&gt;agent-&gt;accept_lang()</h2>
  146. <p>让你确认,用户代理是否包含一种特定的语言。例:</p>
  147. <code>if ($this-&gt;agent-&gt;accept_lang('en'))<br />
  148. &#123;<br />
  149. &nbsp;&nbsp;&nbsp;&nbsp;echo 'You accept English!';<br />
  150. &#125;</code>
  151. <p class="important"><strong>注意:</strong> 这一功能通常不是很可靠,因为有些浏览器不提供语言信息,即使提供了,也不一定准确 </p>
  152. <h2>$this-&gt;agent-&gt;accept_charset()</h2>
  153. <p>让你确认,用户代理是否包含一种特定的字符集。例:</p>
  154. <code>if ($this-&gt;agent-&gt;accept_charset('utf-8'))<br />
  155. &#123;<br />
  156. &nbsp;&nbsp;&nbsp;&nbsp;echo 'You browser supports UTF-8!';<br />
  157. &#125;</code>
  158. <p class="important"><strong>注意:</strong> 这一功能通常不是很可靠,因为有些浏览器不提供字符集信息,或是提供的信息不一定正确 </p><p>&nbsp;</p>
  159. <div id="Contributors">
  160. 翻译贡献者:
  161. Hex, kissmumu</div>
  162. <div id="DocDate">
  163. 最后修改: 2011-02-01 02:11:44</div>
  164. </div>
  165. <!-- END CONTENT -->
  166. <div id="footer">
  167. <p>
  168. 上一个主题:&nbsp;&nbsp;<a href="uri.html">URI 类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  169. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="xmlrpc.html">XML-RPC 类</a> </p>
  170. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  171. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  172. </div>
  173. </body>
  174. </html>