Zend_Config_Xml Zend_Config_Xml pozwala programistom przechowywać dane konfiguracyjne w prostym formacie XML a następnie odczytywać je w aplikacji używając składni zagnieżdżonych właściwości obiektów. Nazwa głównego elementu pliku XML jest nieistotna i może być dowolna. Pierwsze poziomy elementów XML odpowiadają sekcjom danych konfiguracyjnych. Format XML obsługuje hierarchiczne zorganizowanie za pomocą zagnieżdżania elementów XML wewnątrz elementów poziomu sekcji. Zawartość najbardziej zagnieżdżonego elementu XML odpowiada wartości danej konfiguracyjnej. Dziedziczenie sekcji jest obsługiwane za pomocą specjalnego atrybutu XML nazwanego extends, a wartość tego atrybutu odpowiada nazwie sekcji, której dane mają być odziedziczone przez rozszerzającą sekcję. Zwracany typ Dane konfiguracyjne odczytywane przez Zend_Config_Xml są zawsze zwracane jako łańcuchy znaków. Konwersja danych z łańcuchów znaków do innych typów leży w gestii programistów, którzy mogą dopasować to do własnych potrzeb. Użycie Zend_Config_Xml Ten przykład pokazuje podstawowe użycie klasy Zend_Config_Xml do ładowania danych konfiguracyjnych z pliku XML. W tym przykładzie znajdują się dane konfiguracyjne zarówno dla systemu produkcyjnego jak i dla systemu rozbudowywanego. Z tego względu, że dane konfiguracyjne systemu rozbudowywanego są bardzo podobne do tych dla systemu produkcyjnego, sekcja systemu rozbudowywanego dziedziczy po sekcji systemu produkcyjnego. W tym przypadku decyzja jest dowolna i mogłoby to być zrobione odwrotnie, z sekcją systemu produkcyjnego dziedziczącą po sekcji systemu rozbudowywanego, chociaż nie może to być przykładem dla bardziej złożonych sytuacji. Załóżmy, że poniższe dane konfiguracyjne znajdują się w pliku /path/to/config.xml: www.example.com pdo_mysql db.example.com dbuser secret dbname dev.example.com devuser devsecret ]]> Następnie załóżmy, że programista aplikacji potrzebuje danych konfiguracyjnych aplikacji rozbudowywanej z pliku XML. Prostą  sprawą jest załadowanie tych danych określając plik XML oraz sekcję dla aplikacji rozbudowywanej: database->params->host; // wyświetla "dev.example.com" echo $config->database->params->dbname; // wyświetla "dbname" ]]> Używanie atrybutów znaczników w Zend_Config_Xml Komponent Zend_Config_Xml obsługuje także dwa inne sposoby definiowania elementów w pliku konfiguracyjnym. Oba sposoby używają atrybutów. Z tego względu, że atrybuty extends oraz value są zastrzeżone (do rozszerzania sekcji oraz do alternatywnego sposobu użycia atrybutów), nie mogą one być użyte. Pierwszym sposobem użycia atrybutu jest dodanie go w elemencie rodzica. Zostanie on automatycznie przełożony jako element dziecko: ]]> Kolejny sposób tak naprawdę nie zmniejsza objętości pliku konfiguracyjnego, ale ułatwia zarządzanie nim, ponieważ eliminuje konieczność pisania nazw znaczników podwójnie. Po prostu tworzysz pusty znacznik, który zawiera swoją wartość wewnątrz atrybutu value: www.example.com ]]>