<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/book.yaf.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'zh',
  ),
  'this' => 
  array (
    0 => 'yaf.appconfig.php',
    1 => '应用程序配置',
    2 => '应用程序配置',
  ),
  'up' => 
  array (
    0 => 'book.yaf.php',
    1 => 'Yaf',
  ),
  'prev' => 
  array (
    0 => 'yaf.tutorials.php',
    1 => '示例',
  ),
  'next' => 
  array (
    0 => 'class.yaf-application.php',
    1 => 'Yaf_Application',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'zh',
    'path' => 'reference/yaf/appconfig.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="yaf.appconfig" class="chapter">
 <h1 class="title">应用程序配置</h1>

 <p class="para">
  应该为 <span class="methodname"><a href="yaf-application.construct.php" class="methodname">Yaf_Application::__construct()</a></span> 提供配置数组或者 ini 配置文件（参阅 <span class="classname"><a href="class.yaf-config-ini.php" class="classname">Yaf_Config_Ini</a></span>）路径。
 </p>
 <p class="para">
  Yaf 将会自动合并应用程序配置和用户配置。应用程序配置有前缀“yaf.”或“application.”。如果“yaf.”和“application.”同时存在，将会优先接受“application.”。
  <div class="example" id="example-1">
   <p><strong>示例 #1 PHP 数组示例</strong></p>
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />$configs </span><span style="color: #007700">= array(<br />    </span><span style="color: #DD0000">"application" </span><span style="color: #007700">=&gt; array(<br />        </span><span style="color: #DD0000">"directory" </span><span style="color: #007700">=&gt; </span><span style="color: #0000BB">dirname</span><span style="color: #007700">(</span><span style="color: #0000BB">__FILE__</span><span style="color: #007700">),<br />        </span><span style="color: #DD0000">"dispatcher" </span><span style="color: #007700">=&gt; array(<br />            </span><span style="color: #DD0000">"catchException" </span><span style="color: #007700">=&gt; </span><span style="color: #0000BB">0</span><span style="color: #007700">,<br />        ),<br />        </span><span style="color: #DD0000">"view" </span><span style="color: #007700">=&gt; array(<br />            </span><span style="color: #DD0000">"ext" </span><span style="color: #007700">=&gt; </span><span style="color: #DD0000">"phtml"</span><span style="color: #007700">,<br />        ),<br />    ),<br />);<br /><br /></span><span style="color: #0000BB">$app </span><span style="color: #007700">= new </span><span style="color: #0000BB">Yaf_Application</span><span style="color: #007700">(</span><span style="color: #0000BB">$configs</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
  <div class="example" id="example-2">
   <p><strong>示例 #2 ini 文件示例</strong></p>
   <div class="example-contents">
<div class="inicode"><pre class="inicode">[yaf]
yaf.directory = APPLICATION_PATH &quot;/application&quot;
yaf.dispatcher.catchException = 0

[product : yaf]
; user configuration list here</pre>
</div>
   </div>

  </div>
  </p>
  <p class="para">
  <table class="doctable table">
   <caption><strong>Yaf 应用程序配置</strong></caption>
   
    <thead>
     <tr>
      <th>名字</th>
      <th>默认</th>
      <th>更新日志</th>
     </tr>

    </thead>

    <tbody class="tbody">
     <tr>
      <td>application.directory</td>
      <td class="empty">&nbsp;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.ext</td>
      <td>&quot;php&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.view.ext</td>
      <td>&quot;phtml&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.modules</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.library</td>
      <td>application.directory . &quot;/library&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.library.directory</td>
      <td>application.directory . &quot;/library&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.library.namespace</td>
      <td>&quot;&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.bootstrap</td>
      <td>application.directory . &quot;/Bootstrap&quot; . application.ext</td>
      <td></td>
     </tr>

     <tr>
      <td>application.baseUri</td>
      <td>&quot;&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultRoute</td>
      <td class="empty">&nbsp;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.throwException</td>
      <td>1</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.catchException</td>
      <td>0</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultModule</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultController</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultAction</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.system</td>
      <td class="empty">&nbsp;</td>
      <td></td>
     </tr>

    </tbody>
   
  </table>

 </p>

 <p class="para">这是配置指令的简短说明。</p>

 <p class="para">
  <dl>
   
     <dt id="configuration.yaf.directory">
      <code class="parameter">application.directory</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       应用程序的目录，文件夹包含“controllers”、“views”、“models”、“plugins”。
      </p>
      <p class="para">
       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <p class="para">
         此为唯一没有默认值的配置条目，应该始终手动定义它。
        </p>
       </p></blockquote>
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.ext">
      <code class="parameter">application.ext</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       PHP 脚本的扩展名，类的自动加载需要（<span class="classname"><a href="class.yaf-loader.php" class="classname">Yaf_Loader</a></span>）。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.view.ext">
      <code class="parameter">application.view.ext</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       视图模板脚本的文件扩展名。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.modules">
      <code class="parameter">application.modules</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
        注册的模块列表，以逗号分隔，用于路由处理，特别是当PATH_INFO超过三段的时候， 
      </p>
      <p class="para">
        Yaf需要用它来判断第一段是否是一个模块。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.library">
      <code class="parameter">application.library</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
        本地类库的目录，参见 <span class="classname"><a href="class.yaf-loader.php" class="classname">Yaf_Loader</a></span> 和
       <a href="yaf.configuration.php#ini.yaf.library" class="link">yaf.library</a>。
       </p>
       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <p class="para">
         Yaf 2.1.6 以后，该配置项可以是数组。类库的路径将尝试使用 <a href="yaf.appconfig.php#configuration.yaf.library.directory" class="link">application.library.directory</a> 中设置的条目。
        </p>
       </p></blockquote>
     </dd>
    
    
     <dt id="configuration.yaf.library.directory">
      <code class="parameter">application.library.directory</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       Alias of <a href="yaf.appconfig.php#configuration.yaf.library" class="link">application.library</a>. Introduced
       in Yaf 2.1.6
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.library.namespace">
      <code class="parameter">application.library.namespace</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       逗号分隔的本地类库命名空间前缀。
      </p>
      <p class="para">
       Yaf2.1.6以后加入
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.bootstrap">
      <code class="parameter">application.bootstrap</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       Bootstrap类脚本文件的绝对路径。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.baseuri">
      <code class="parameter">application.baseUri</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       路由处理中需要忽略的路径前缀。举个例子，请求&quot;/prefix/controller/action&quot;时。如果你将application.baseUri设置为&quot;/prefix&quot;，那么只有&quot;/controller/action&quot;会被当做路由路径。
      </p>
      <p class="para">
       通常不需要设置此值。 
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.throwexception">
      <code class="parameter">application.dispatcher.throwException</code>
      <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
     </dt>
     <dd>
      <p class="para">
       如果设置为 On，Yaf 会在发生错误的地方抛出异常。参见
       <span class="methodname"><a href="yaf-dispatcher.throwexception.php" class="methodname">Yaf_Dispatcher::throwException()</a></span>。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.catchexception">
      <code class="parameter">application.dispatcher.catchException</code>
      <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
     </dt>
     <dd>
      <p class="para">
       如果设置为 On，当在存在未处理的异常时，Yaf 将转发到 Error controller/Action。参见
       <span class="methodname"><a href="yaf-dispatcher.catchexception.php" class="methodname">Yaf_Dispatcher::catchException()</a></span>。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaulRoute">
      <code class="parameter">application.dispatcher.defaultRoute</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       默认路由，如果未指定，默认使用静态路由。参见
       <span class="methodname"><a href="yaf-router.addroute.php" class="methodname">Yaf_Router::addRoute()</a></span>。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaultmodule">
      <code class="parameter">application.dispatcher.defaultModule</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       默认模块名，参见
       <span class="methodname"><a href="yaf-dispatcher.setdefaultmodule.php" class="methodname">Yaf_Dispatcher::setDefaultModule()</a></span>。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaultcontroller">
      <code class="parameter">application.dispatcher.defaultController</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       默认控制器名，参见
       <span class="methodname"><a href="yaf-dispatcher.setdefaultcontroller.php" class="methodname">Yaf_Dispatcher::setDefaultController()</a></span>。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaultaction">
      <code class="parameter">application.dispatcher.defaultAction</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       默认动作名，参见
       <span class="methodname"><a href="yaf-dispatcher.setdefaultaction.php" class="methodname">Yaf_Dispatcher::setDefaultAction()</a></span>。
      </p>
     </dd>
    

    
     <dt id="configuration.yaf.system">
      <code class="parameter">application.system</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       在application.ini中设置Yaf运行时配置，如：
       <a href="yaf.configuration.php#ini.yaf.lowcase-path" class="link">application.system.lowcase_path</a>
       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <p class="para">
        仅有 <strong><code><a href="info.constants.php#constant.ini-all">INI_ALL</a></code></strong> 配置项能这样设置
       </p>
       </p></blockquote>
      </p>
     </dd>
    

  </dl>
 </p>
</div>
<?php manual_footer($setup); ?>