Zend_Config-Introduction.xml 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <sect1 id="zend.config.introduction">
  2. <title>简介</title>
  3. <para>
  4. <code>Zend_Config</code>被设计在应用程序中简化访问和使用配置数据。它为在应用程序代码中访问这样的配置数据提供了一个基于用户接口的嵌入式对象属性。配置数据可能来自于各种支持等级结构数据存储的媒体。当前<code>Zend_Config</code>为存储在<link linkend="zend.config.adapters.ini"><code>Zend_Config_Ini</code></link> 和<link linkend="zend.config.adapters.xml"><code>Zend_Config_Xml</code></link>的文本文件中的配置数据提供了适配器。
  5. </para>
  6. <example id="zend.config.introduction.example.using">
  7. <title>使用 Zend_Config 本身 </title>
  8. <para>
  9. 通常用户可以使用象<link linkend="zend.config.adapters.ini"><code>Zend_Config_Ini</code></link> 或 <link linkend="zend.config.adapters.xml"><code>Zend_Config_Xml</code></link>适配器类的其中之一,但如果配置数据在PHP数组里可用,为了使用一个简单的面向对象的接口,可以简单地传递数据到<code>Zend_Config</code>构造器:
  10. </para>
  11. <programlisting role="php"><![CDATA[
  12. // 给出一个配置数据的数组
  13. $configArray = array(
  14. 'webhost' => 'www.example.com',
  15. 'database' => array(
  16. 'adapter' => 'pdo_mysql',
  17. 'params' => array(
  18. 'host' => 'db.example.com',
  19. 'username' => 'dbuser',
  20. 'password' => 'secret',
  21. 'dbname' => 'mydatabase'
  22. )
  23. )
  24. );
  25. // 基于配置数据创建面向对象的 wrapper
  26. $config = new Zend_Config($configArray);
  27. // 输出配置数据 (结果在'www.example.com'中)
  28. echo $config->webhost;
  29. // 使用配置数据来连接数据库
  30. $db = Zend_Db::factory($config->database->adapter,
  31. $config->database->params->toArray());
  32. // 另外的用法:简单地传递 Zend_Config 对象。
  33. // Zend_Db factory 知道如何翻译它。
  34. $db = Zend_Db::factory($config->database);
  35. ]]>
  36. </programlisting>
  37. </example>
  38. <para>
  39. 如上例所示,<code>Zend_Config</code> 提供嵌套的对象属性语句来访问传递给它的构造器的配置数据。
  40. </para>
  41. <para>
  42. 连同面向对象访问数据值,<code>Zend_Config</code>也有<code>get()</code>方法,如果数据元素不存在,它将返回提供的缺省值,例如:
  43. </para>
  44. <programlisting role="php"><![CDATA[
  45. $host = $config->database->get('host', 'localhost');
  46. ]]>
  47. </programlisting>
  48. <example id="zend.config.introduction.example.file.php">
  49. <title>Using Zend_Config with a PHP Configuration File</title>
  50. <para>
  51. It is often desirable to use a pure PHP-based configuration file. The following code illustrates how easily
  52. this can be accomplished:
  53. </para>
  54. <programlisting role="php"><![CDATA[
  55. // config.php
  56. return array(
  57. 'webhost' => 'www.example.com',
  58. 'database' => array(
  59. 'adapter' => 'pdo_mysql',
  60. 'params' => array(
  61. 'host' => 'db.example.com',
  62. 'username' => 'dbuser',
  63. 'password' => 'secret',
  64. 'dbname' => 'mydatabase'
  65. )
  66. )
  67. );
  68. ]]>
  69. </programlisting>
  70. <programlisting role="php"><![CDATA[
  71. // Configuration consumption
  72. $config = new Zend_Config(require 'config.php');
  73. // Print a configuration datum (results in 'www.example.com')
  74. echo $config->webhost;
  75. ]]>
  76. </programlisting>
  77. </example>
  78. </sect1>
  79. <!--
  80. vim:se ts=4 sw=4 et:
  81. -->