Введение в Zend Framework

 Learning Zend Framework

appendix

 Zend Framework Reference


  • Zend_Gdata
  • Zend_Http
  • Zend_InfoCard
  • Zend_Json
  • Zend_Layout
  • Zend_Ldap
  • Zend_Loader
  • Zend_Locale
  • Zend_Log
  • Zend_Mail
  • Zend_Markup
  • Zend_Measure
  • Zend_Memory
  • Zend_Mime
  • Zend_Navigation
  • Zend_Oauth
  • Zend_OpenId
  • Zend_Paginator
  • Zend_Pdf
  • Zend_ProgressBar
  • Zend_Queue
  • Zend_Reflection
  • Zend_Registry
  • Zend_Rest

  • Zend_Search_Lucene
  • Zend_Serializer
  • Zend_Server
  • Zend_Service
  • Zend_Session
  • Zend_Soap
  • Zend_Tag
  • Zend_Test
  • Zend_Text
  • Zend_TimeSync
  • Zend_Tool
  • Zend_Tool_Framework
  • Zend_Tool_Project
  • Zend_Translate
  • Zend_Uri
  • Zend_Validate
  • Zend_Version
  • Zend_View
  • Zend_Wildfire
  • Zend_XmlRpc
  • ZendX_Console_Process_Unix
  • ZendX_JQuery
  • Ttranslation 27.4% Update 2010-11-28 - Revision 23238 - Version ZF 1.11.x

    21.5. Zend_Config_Xml

    Zend_Config_Xml дает разработчикам возможность хранить конфигурационные данные в простом формате XML и читать их посредством синтаксиса вложенных свойств объектов. Корневой элемент в файле или строке с XML не имеет значения и ему может быть дано любое имя. Первый уровень элементов XML соответствует разделам конфигурационных данных. Формат XML поддерживает иерархическую организацию данных через вложенность элементов ниже элементов уровня разделов. Содержимое конечного элемента соответствует значению элемента конфигурационных данных. Наследование разделов поддерживается через специальный атрибут extends, значение атрибута соответствует разделу, данные которого наследуются в раздел с этим атрибутом.

    [Замечание] Тип возвращаемых данных

    Конфигурационные данные, прочитанные в Zend_Config_Xml, всегда возвращаются как строки. Приведение данных из строк к требуемым типам предоставляется разработчикам.

    Пример 21.4. Использование Zend_Config_Xml

    Данный пример демонстрирует основы использования Zend_Config_Xml для загрузки конфигурационных данных из файла XML. В этом примере используются конфигурационные данные для производственной и промежуточной систем. Поскольку конфигурационные данные промежуточной системы очень похожи на конфигурационные данные для производственной системы, то "промежуточный" (staging) раздел наследует от "производственного" (production) раздела. В данном случае выбор произвольный, т.е. может быть и наоборот — "производственный" раздел наследует от "промежуточного", хотя это может не подходить в более сложных случаях. Допустим, конфигурационные данные находятся в файле /path/to/config.xml:

    <?xml version="1.0"?>
    <configdata>
        <production>
            <webhost>www.example.com</webhost>
            <database>
                <adapter>pdo_mysql</adapter>
                <params>
                    <host>db.example.com</host>
                    <username>dbuser</username>
                    <password>secret</password>
                    <dbname>dbname</dbname>
                </params>
            </database>
        </production>
        <staging extends="production">
            <database>
                <params>
                    <host>dev.example.com</host>
                    <username>devuser</username>
                    <password>devsecret</password>
                </params>
            </database>
        </staging>

    Далее предположим, что разработчику приложения нужны "промежуточные" конфигурационные данные из файла XML. Загрузить эти данные, указав файл XML и нужный раздел, довольно просто:

    $config = new Zend_Config_Xml('/path/to/config.xml''staging');

    echo 
    $config->database->params->host;   // выведет "dev.example.com"
    echo $config->database->params->dbname// выведет "dbname"

    Пример 21.5. Использование тегов в Zend_Config_Xml

    Zend_Config_Xml также поддерживает два дополнительных способа определения узлов в конфигурации. В обоих способах используются атрибуты. Поскольку атрибуты extends и value являются зарезервированными ключевыми словами (value используется во втором способе с применением атрибутов), то они не должны использоваться здесь. Первый способ с использованием атрибутов состоит в добавлении атрибутов в родительский узел, они потом будут преобразованы в потомки этого узла:

    <?xml version="1.0"?>
    <configdata>
        <production webhost="www.example.com">
            <database adapter="pdo_mysql">
                <params host="db.example.com" username="dbuser" password="secret"
                        dbname="dbname"/>
            </database>
        </production>
        <staging extends="production">
            <database>
                <params host="dev.example.com" username="devuser"
                        password="devsecret"/>
            </database>
        </staging>
    </configdata>

    Другой способ не делает конфигурацию заметно короче, но облегчает ее поддержку благодаря тому, что не нужно писать имена тегов дважды. Вы просто создаете пустой тег, значение которого содержится в атрибуте value:

    <?xml version="1.0"?>
    <configdata>
        <production>
            <webhost>www.example.com</webhost>
            <database>
                <adapter value="pdo_mysql"/>
                <params>
                    <host value="db.example.com"/>
                    <username value="dbuser"/>
                    <password value="secret"/>
                    <dbname value="dbname"/>
                </params>
            </database>
        </production>
        <staging extends="production">
            <database>
                <params>
                    <host value="dev.example.com"/>
                    <username value="devuser"/>
                    <password value="devsecret"/>
                </params>
            </database>
        </staging>
    </configdata>

    [Замечание] Передача строки с XML

    Zend_Config_Xml также может загружать XML непосредственно из строки, которая может быть получена, например, из базы данных. Строка передается конструктору в качестве первого параметра и должна начинаться с символов '<?xml':

    $string = <<<EOT
    <?xml version="1.0"?>
    <config>
        <production>
            <db>
                <adapter value="pdo_mysql"/>
                <params>
                    <host value="db.example.com"/>
                </params>
            </db>
        </production>
        <staging extends="production">
            <db>
                <params>
                    <host value="dev.example.com"/>
                </params>
            </db>
        </staging>
    </config>
    EOT;

    $config = new Zend_Config_Xml($string'staging');
    digg delicious meneame google twitter technorati facebook

    Comments

    Loading...