Zend_Config-Introduction.xml 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.config.introduction">
  5. <title>導入</title>
  6. <para>
  7. <classname>Zend_Config</classname> は、アプリケーションの設定データを
  8. 簡単に使用できるようにするために設計されたものです。
  9. 階層構造になったプロパティを使用して、設定データを簡単に
  10. アプリケーションに読み込めるようになっています。
  11. 設定データは、階層構造のデータ保存をサポートしている
  12. さまざまな媒体から読み込むことができます。
  13. 現時点で <classname>Zend_Config</classname> が提供している設定データアダプタは
  14. <link linkend="zend.config.adapters.ini"><classname>Zend_Config_Ini</classname></link>
  15. と <link linkend="zend.config.adapters.xml"><classname>Zend_Config_Xml</classname></link>
  16. の二種類で、テキストファイルに格納された設定データを使用できるようになっています。.
  17. </para>
  18. <example id="zend.config.introduction.example.using">
  19. <title><classname>Zend_Config</classname> の使用例</title>
  20. <para>
  21. 通常は、<link linkend="zend.config.adapters.ini"><classname>Zend_Config_Ini</classname></link>
  22. あるいは <link linkend="zend.config.adapters.xml"><classname>Zend_Config_Xml</classname></link>
  23. のようなアダプタクラスを使用することが想定されています。
  24. しかし、もし設定データが PHP の配列として存在するのなら、
  25. 単にそれを <classname>Zend_Config</classname> のコンストラクタに渡すだけで、
  26. シンプルなオブジェクト指向のインターフェイスを使用することができます。
  27. </para>
  28. <programlisting role="php"><![CDATA[
  29. // 設定データは配列で渡されます
  30. $configArray = array(
  31. 'webhost' => 'www.example.com',
  32. 'database' => array(
  33. 'adapter' => 'pdo_mysql',
  34. 'params' => array(
  35. 'host' => 'db.example.com',
  36. 'username' => 'dbuser',
  37. 'password' => 'secret',
  38. 'dbname' => 'mydatabase'
  39. )
  40. )
  41. );
  42. // 設定データに対するオブジェクト指向のラッパーを作成します
  43. $config = new Zend_Config($configArray);
  44. // 設定データを表示します (結果は 'www.example.com' となります)
  45. echo $config->webhost;
  46. // 設定データを使用してデータベースに接続します
  47. $db = Zend_Db::factory($config->database->adapter,
  48. $config->database->params->toArray());
  49. // もうひとつの方法: 単に Zend_Config オブジェクトを渡します
  50. // Zend_Db のファクトリは、その処理方法を知っています
  51. $db = Zend_Db::factory($config->database);
  52. ]]>
  53. </programlisting>
  54. </example>
  55. <para>
  56. 上の例で説明したように、<classname>Zend_Config</classname> を使用すると、
  57. コンストラクタに渡されたデータについて、
  58. 階層化されたプロパティの形式でアクセスできるようになります。
  59. </para>
  60. <para>
  61. このようにオブジェクト思考形式でデータの値にアクセスするだけでなく、
  62. <classname>Zend_Config</classname> では <code>get()</code> メソッドも用意しています。
  63. これは、指定した要素が存在しない場合にデフォルト値を返すように設定できます。
  64. たとえば次のように使用します。
  65. </para>
  66. <programlisting role="php"><![CDATA[
  67. $host = $config->database->get('host', 'localhost');
  68. ]]>
  69. </programlisting>
  70. <example id="zend.config.introduction.example.file.php">
  71. <title><classname>Zend_Config</classname> における PHP 設定ファイルの使用法</title>
  72. <para>
  73. 設定ファイルそのものを PHP で書きたいこともあるでしょう。
  74. 以下のようにすると、簡単にそれを行うことができます。
  75. </para>
  76. <programlisting role="php"><![CDATA[
  77. // config.php
  78. return array(
  79. 'webhost' => 'www.example.com',
  80. 'database' => array(
  81. 'adapter' => 'pdo_mysql',
  82. 'params' => array(
  83. 'host' => 'db.example.com',
  84. 'username' => 'dbuser',
  85. 'password' => 'secret',
  86. 'dbname' => 'mydatabase'
  87. )
  88. )
  89. );
  90. ]]>
  91. </programlisting>
  92. <programlisting role="php"><![CDATA[
  93. // 設定を読み込みます
  94. $config = new Zend_Config(require 'config.php');
  95. // 設定データを出力します (この結果は 'www.example.com' です)
  96. echo $config->webhost;
  97. ]]>
  98. </programlisting>
  99. </example>
  100. </sect1>
  101. <!--
  102. vim:se ts=4 sw=4 et:
  103. -->