uri.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  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>URI 类 - 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/uri.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;URI 类 </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>URI 类</h1>
  61. <p>URI类提供了帮助你分割URI字符串的函数集合。如果你使用URI路由功能,那么你就可以通过分段来重新分发地址栏信息。</p>
  62. <p class="important"><strong>注意:</strong> URI类会被系统自动初始化,不必手动启用该功能。</p>
  63. <h2>$this-&gt;uri-&gt;segment(<var>n</var>)</h2>
  64. <p>它允许你重新分割一个详细的URI分段。 <var>n</var> 为你想要得到的段数。
  65. 分割数按照从左至右的顺序编排。 例如,如果你完整的URL的地址如下:</p>
  66. <code>http://example.com/index.php/news/local/metro/crime_is_up</code>
  67. <p>每个URI分段的数字编号为:</p>
  68. <ol>
  69. <li>news</li>
  70. <li>local</li>
  71. <li>metro</li>
  72. <li>crime_is_up</li>
  73. </ol>
  74. <p>默认情况下URI没有分段那么该函数返回 FALSE(布尔值)。如果分段信息丢失,Segment函数还有第二个参数用来设置你的默认值。
  75. 例如,这样设置后,当发生错误时,函数就会返回数字“0”。
  76. </p>
  77. <code>$product_id = $this-&gt;uri-&gt;segment(3, 0);</code>
  78. <p>如果没有该参数你的代码必须得像下面这样写:</p>
  79. <code>if ($this-&gt;uri-&gt;segment(3) === FALSE)<br />
  80. &#123;<br />
  81. &nbsp;&nbsp;&nbsp;&nbsp;$product_id = 0;<br />
  82. &#125;<br />
  83. else<br />
  84. &#123;<br />
  85. &nbsp;&nbsp;&nbsp;&nbsp;$product_id = $this-&gt;uri-&gt;segment(3);<br />
  86. &#125;<br />
  87. </code>
  88. <h2>$this-&gt;uri-&gt;rsegment(<var>n</var>)</h2>
  89. <p>这个函数和上面的函数基本功能一样,不同点在于它允许你在开启CodeIgniter的<a href="../general/routing.html">URI路由</a>功能时进行详细分割并重新分发URI信息</P>
  90. <h2>$this-&gt;uri-&gt;slash_segment(<var>n</var>)</h2>
  91. <p>这个函数几乎和<dfn>$this-&gt;uri-&gt;segment()</dfn>一模一样,不过它可以通过第二个参数(" ","leading","both")给返回的URI参数加上“/”线,
  92. 如果不使用该参数,就会在后面增加斜画线。例如:
  93. </p>
  94. <code>$this-&gt;uri-&gt;slash_segment(<var>3</var>);<br />
  95. $this-&gt;uri-&gt;slash_segment(<var>3</var>, 'leading');<br />
  96. $this-&gt;uri-&gt;slash_segment(<var>3</var>, 'both');</code>
  97. <p>返回:</p>
  98. <ol>
  99. <li>segment/</li>
  100. <li>/segment</li>
  101. <li>/segment/</li>
  102. </ol>
  103. <h2>$this-&gt;uri-&gt;slash_rsegment(<var>n</var>)</h2>
  104. <p>这个函数功能同上面的函数,不同点在于它允许你在开启CodeIgniter的<a href="../general/routing.html">URI路由</a>功能时进行详细分割并重新分发URI信息并可以增加斜线“/”。</p>
  105. <h2>$this-&gt;uri-&gt;uri_to_assoc(<var>n</var>)</h2>
  106. <p>你可以使用这个函数把每个分段信息以"标识字"=>"具体值"的形式存放在一个联合数组Array()里。
  107. 注意这个URI:</p>
  108. <code>index.php/user/search/name/joe/location/UK/gender/male</code>
  109. <p>使用这个函数你可以把URI以如下原型翻转到联合数组中:</p>
  110. <code>[array]<br />
  111. (<br />
  112. &nbsp;&nbsp;&nbsp;&nbsp;'name' => 'joe'<br />
  113. &nbsp;&nbsp;&nbsp;&nbsp;'location' => 'UK'<br />
  114. &nbsp;&nbsp;&nbsp;&nbsp;'gender' => 'male'<br />
  115. )</code>
  116. <p>函数第一个参数可以设置偏移量,默认设置为<kbd>3</kbd>,因为一般情况下你的URI包含 控制器名 / 函数名 作为第一个和第二个分段。
  117. 例如:</p>
  118. <code>
  119. $array = $this-&gt;uri-&gt;uri_to_assoc(3);<br />
  120. <br />
  121. echo $array['name'];
  122. </code>
  123. <p>第二个参数可以用来设置"标识字",这样返回的数组总会包含索引里的标识字,甚至在丢失URI的情况下也是如此。例如:</p>
  124. <code>
  125. $default = array('name', 'gender', 'location', 'type', 'sort');<br />
  126. <br />
  127. $array = $this-&gt;uri-&gt;uri_to_assoc(3, $default);</code>
  128. <p>如果URI不包含对应你所给标识字的具体值时,该索引的值会被设置为"FALSE"。</P>
  129. <p>最后,如果相应的具体值找不到给定的标识字时(若URI段数为是一个单数时)具体值也会被设置为"FALSE"(布尔值)</p>
  130. <h2>$this-&gt;uri-&gt;ruri_to_assoc(<var>n</var>)</h2>
  131. <p>这个函数和上面的函数基本功能一样,不同点在于它允许你在开启CodeIgniter的<a href="../general/routing.html">URI路由</a>功能时把URI信息分割并翻转到联合数组中去。</P>
  132. <h2>$this-&gt;uri-&gt;assoc_to_uri()</h2>
  133. <p>这个函数的功能和uri_to_assoc的功能找相反,它把数组里的信息翻转成URI地址,例如:</p>
  134. <code>$array = array('product' => 'shoes', 'size' => 'large', 'color' => 'red');<br />
  135. <br />
  136. $str = $this-&gt;uri-&gt;assoc_to_uri($array);<br />
  137. <br />
  138. // 输出: product/shoes/size/large/color/red
  139. </code>
  140. <h2>$this-&gt;uri-&gt;uri_string()</h2>
  141. <p>返回一个包含完整URI信息的字符串。例如,假设以下为你的完整URL:</p>
  142. <code>http://example.com/index.php/news/local/345</code>
  143. <p>函数将返回如下字符串:</p>
  144. <code>news/local/345</code>
  145. <h2>$this-&gt;uri-&gt;ruri_string()</h2>
  146. <p>这个函数和上面的函数基本功能一样,不同点在于它允许你在开启CodeIgniter的<a href="../general/routing.html">URI路由</a>功能时把URI转换成对应的字符串。</P>
  147. <h2>$this-&gt;uri-&gt;total_segments()</h2>
  148. <p>返回总的URI的段数</p>
  149. <h2>$this-&gt;uri-&gt;total_rsegments()</h2>
  150. <p>这个函数和上面的函数基本功能一样,不同点在于它允许你在开启CodeIgniter的<a href="../general/routing.html">URI路由</a>功能时返回URI的段数。</P>
  151. <h2>$this-&gt;uri-&gt;segment_array()</h2>
  152. <p>返回一个包含URI分段的数组。例如:</p>
  153. <code>
  154. $segs = $this-&gt;uri-&gt;segment_array();<br />
  155. <br />
  156. foreach ($segs as $segment)<br />
  157. &#123;<br />
  158. &nbsp;&nbsp;&nbsp;&nbsp;echo $segment;<br />
  159. &nbsp;&nbsp;&nbsp;&nbsp;echo '&lt;br />';<br />
  160. &#125;</code>
  161. <h2>$this-&gt;uri-&gt;rsegment_array()</h2>
  162. <p>这个函数和上面的函数基本功能一样,不同点在于它允许你在开启 CodeIgniter 的<a href="../general/routing.html"> URI 路由</a>功能时返回 URI 的数组。</p><p>&nbsp;</p>
  163. <div id="Contributors">
  164. 翻译贡献者:
  165. Hex, lomatus</div>
  166. <div id="DocDate">
  167. 最后修改: 2013-03-22 07:43:09</div>
  168. </div>
  169. <!-- END CONTENT -->
  170. <div id="footer">
  171. <p>
  172. 上一个主题:&nbsp;&nbsp;<a href="unit_testing.html">单元测试类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  173. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="user_agent.html">User-Agent 类</a> </p>
  174. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  175. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  176. </div>
  177. </body>
  178. </html>