config.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  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>配置类 - 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/config.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;配置类 </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>配置类</h1>
  61. <p>该配置类提供一种方法来进行偏好设置。该偏好来源于默认的配置文件(<samp>application/config/config.php</samp>) 或您自己定制的配置文件。</p>
  62. <p class="important"><strong>注意:</strong>该类已经自动加载而无需手动启用。</p>
  63. <h2>分析配置文件</h2>
  64. <p>默认情况下,CodeIgniter已经有一个主要的配置文件,位于<samp>application/config/config.php</samp>。如果你用文本编辑器打开你会看到配置项目被存储在一个叫<var>$config</var>的数组里。</p>
  65. <p>您可以添加您自己的配置项目到这个文件里,或者您更愿意让您自己的配置项目与原配置项目分开(假设你需要额外的配置项),简单的创建一个文件并保存到<dfn>config</dfn>这个文件夹里就行了。</p>
  66. <p><strong>提示:</strong> 如果你想建立一个和主要配置文件一样格式的配置文件,把你的配置项目建立在一个名为<var>$config</var>的数组中,即使配置文件中有相同的数组名,CodeIgniter也能智能的管理这些文件而不会发生冲突.</p>
  67. <h2>加载配置文件</h2>
  68. <p><strong>Note:</strong> CodeIgniter 会自动加载主要的配置文件&#40;<samp>application/config/config.php</samp>&#41;,
  69. 所以你只需要加载你自己创建的配置文件</p>
  70. <p>有两种方法来加载配置文件:</p>
  71. <ol><li><strong>手动加载</strong>
  72. <p>为了加载一个你自定义的配置文件,你需要在 <a href="../general/controllers.html">controller</a> 中这样做:</p>
  73. <code>$this-&gt;config-&gt;load('<var>filename</var>');</code>
  74. <p>这里的 <var>filename</var> 是你自定义的配置文件的文件名,这个文件名没有 .php 的扩展名.</p>
  75. <p>如果你需要加载多个自定义配置文件,一般情况下它们会被合并成一个数组。然而,如果在不同的配置文件中存在同名的索引,那么会发生冲突。为了避免这个问题,你可以把第二个参数设置为 <kbd>TRUE</kbd> ,这可以使每个配置文件的内容存储在一个单独的数组中,数组的索引就是配置文件的文件名。请看下面的例子:</p>
  76. <code>
  77. // 用这样的方式保存为一个数组: $this-&gt;config['blog_settings'] = $config<br />
  78. $this-&gt;config-&gt;load('<var>blog_settings</var>', <kbd>TRUE</kbd>);</code>
  79. <p>请阅读下面名为 <dfn>获取配置元素</dfn> 的部分以了解在这样的方式下如何取得配置信息</p>
  80. <p>第三个参数允许屏蔽当配置文件不存在时产生的错误信息:</p>
  81. <code>$this-&gt;config-&gt;load('<var>blog_settings</var>', <dfn>FALSE</dfn>, <kbd>TRUE</kbd>);</code>
  82. </li>
  83. <li><strong>自动加载</strong>
  84. <p>如果你需要一个特定配置文件在全局范围内都能使用,你可以使系统自动加载它。要自动加载配置,请打开文件 <strong>autoload.php</strong>,它在 <samp>application/config/autoload.php</samp>,然后按照文件中的提示增加你想要自动加载的配置文件。</p>
  85. </li>
  86. </ol>
  87. <h2>获取配置元素</h2>
  88. <p>从配置文件中检索元素,使用下面的函数:</p>
  89. <code>$this-&gt;config-&gt;item('<var>item name</var>');</code>
  90. <p>其中 <var>item name</var> 是 $config 数组中你期望检索的索引. 例如,要获得您选择的语言,你可以这样做:</p>
  91. <code>$lang = $this-&gt;config-&gt;item('language');</code>
  92. <p>当试图获取的元素不存在时,此函数返回 FALSE (boolean) 。</p>
  93. <p>如果你为了用具体的索引来声明配置数组(避免上述索引重名问题)而在函数 <kbd>$this-&gt;config-&gt;load</kbd> 中使用了第二个参数,你可以通过指定函数 <kbd>$this-&gt;config-&gt;item()</kbd> 的第二个参数为特定索引名来获取相关的配置元素。例如:</p>
  94. <code>
  95. // 载入一个名为 blog_settings.php 的配置文件,然后把它声明为一个索引为 "blog_settings" 的数组<br />
  96. $this-&gt;config-&gt;load('<var>blog_settings</var>', <kbd>TRUE</kbd>);<br /><br />
  97. // 在数组 blog_settings 中获取名为 site_name 的配置元素<br />
  98. $site_name = $this-&gt;config-&gt;item('<dfn>site_name</dfn>', '<var>blog_settings</var>');<br /><br />
  99. // 另外一种方式:<br />
  100. $blog_config = $this-&gt;config-&gt;item('<var>blog_settings</var>');<br />
  101. $site_name = $blog_config['site_name'];</code>
  102. <h2>设置一项元素</h2>
  103. <p>如果你想动态设置/改变一个现有的配置元素,你可以使用:</p>
  104. <code>$this-&gt;config-&gt;set_item('<var>item_name</var>', '<var>item_value</var>');</code>
  105. <p>其中 <var>item_name</var> 是你希望改变的 $config 数组的索引, <var>item_value</var> 是改变后的值.</p>
  106. <p><strong>注意:</strong>这里修改的配置元素并不是改变配置文件(application/config/config.php)的值,仅改变当前<var>$this-&gt;config-&gt;item()</var>方法取到的值</p>
  107. <a name="environments"></a>
  108. <h2>环境</h2>
  109. <p>
  110. 你可以根据当前的开发/服务环境读取不同的配置文件.
  111. <kbd>ENVIRONMENT</kbd> 常量在 index.php 定义,
  112. 在 <a href="../general/environments.html">处理多环境</a>
  113. 一章有详细的描述和说明.
  114. </p>
  115. <p>
  116. 一个特定环境的配置文件,
  117. 需要按此路径创建或者复制一个文件: application/config/&#123;ENVIRONMENT&#125;/&#123;FILENAME&#125;.php
  118. </p>
  119. <p>例如,要创建一个仅'production'环境的 config.php, 你应该:</p>
  120. <ol>
  121. <li>创建文件夹:application/config/production/</li>
  122. <li>复制现有的 config.php 到上面的文件夹</li>
  123. <li>编辑 application/config/production/config.php 设定你在'production'环境所需的设置</li>
  124. </ol>
  125. <p>
  126. 当你设置 <kbd>ENVIRONMENT</kbd> 常量为 'production',
  127. 你刚创建的仅'production'环境的 config.php 配置文件将被加载。
  128. </p>
  129. <p>你可以放置以下配置文件到特定环境的文件夹:</p>
  130. <ul>
  131. <li>默认的 CodeIgniter 配置文件</li>
  132. <li>你自己的用户配置文件</li>
  133. </ul>
  134. <p><strong>注意:</strong> CodeIgniter 会先尝试加载当前环境的配置文件。 如果文件不存在,将加载全局配置文件,例如 &#40;<samp>application/config/</samp>&#41; 。 这意味着你没有必要把 <strong>所有的</strong>配置文件放在特定环境的文件夹里, &minus; 仅仅把各环境不同的放进去就行了。</p>
  135. <h2>辅助函数</h2>
  136. <p>配置类有以下辅助函数:</p>
  137. <h2>$this-&gt;config-&gt;site_url();</h2>
  138. <p>该函数得到你网站的 URL,其中包含了你在 config 文件中设置的 "index" 的值。</p>
  139. <h2>$this-&gt;config-&gt;base_url();</h2>
  140. <p>该函数返回站点的根 URL,可以在这个函数后拼接一个 URL 路径,用以生成 CSS 或图片文件的 URL。</p>
  141. <p>以上两个函数一般通过<a href="../helpers/url_helper.html">URL 辅助函数</a>中相应的函数(site_url() 和 base_url())调用。</p>
  142. <h2>$this-&gt;config-&gt;system_url();</h2>
  143. <p>该函数得到 <dfn>system 文件夹</dfn>的 URL。</p><p>&nbsp;</p>
  144. <div id="Contributors">
  145. 翻译贡献者:
  146. airwin, aykirk, borisauschina, Hex, localtest, skey, szlinz, tanqimin, tinsn, xwjie, zhupeng, 暗夜星辰</div>
  147. <div id="DocDate">
  148. 最后修改: 2013-08-05 11:33:15</div>
  149. </div>
  150. <!-- END CONTENT -->
  151. <div id="footer">
  152. <p>
  153. 上一个主题:&nbsp;&nbsp;<a href="calendar.html">日历类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  154. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="../database/index.html">数据库类</a> </p>
  155. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  156. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  157. </div>
  158. </body>
  159. </html>