Zend_Registry.xml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15215 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.registry.using">
  5. <title>Die Registry verwenden</title>
  6. <para>
  7. Eine Registry ist ein Container für das Speichern von Objekten und Werten im
  8. Raum der Anwendung. Durch das Speichern der Werte in einer Registry steht das
  9. selbe Objekt immer innerhalb der kompletten Anwendung zur Verfügung.
  10. Dieser Mechanismus ist eine Alernative zur Verwendung eines Globalen Speichers.
  11. </para>
  12. <para>
  13. Die typische Methode um Registries mit dem Zend Framework zu verwenden ist
  14. durch die statischen Methoden in der <classname>Zend_Registry</classname> Klasse. Alternativ kann die
  15. Registry als Arrayobjekt verwendet werden, und so können Elemente welche darin gespeichert
  16. wurden durch ein gewöhnliches Array-artiges Interface verwendet werden.
  17. </para>
  18. <sect2 id="zend.registry.using.storing">
  19. <title>Werte in die Registry speichern</title>
  20. <para>
  21. Verwende die statische Methode <code>set()</code> um einen Eintrag in der Registry zu Speichern.
  22. </para>
  23. <example id="zend.registry.using.storing.example">
  24. <title>Beispiel der Verwendung der set() Methode</title>
  25. <programlisting role="php"><![CDATA[
  26. Zend_Registry::set('index', $value);
  27. ]]></programlisting>
  28. </example>
  29. <para>
  30. Der zurückgegebene Wert kann ein Objekt, ein Array oder ein Skalar sein.
  31. Der gespeicherte Wert in einem speziellen Eintrag der Registry
  32. kann durch den Aufruf der <code>set()</code> Methode verändert werden um
  33. den Eintrag auf einen neuen Wert zu setzen.
  34. </para>
  35. <para>
  36. Der Index kann ein Skalar (<code>null</code>, String oder Nummer),
  37. sowie ein gewöhnliches Array sein.
  38. </para>
  39. </sect2>
  40. <sect2 id="zend.registry.using.retrieving">
  41. <title>Werte aus der Registry lesen</title>
  42. <para>
  43. Um einen Eintrag von der Registry zu erhalten, kann die statische
  44. <code>get()</code> Methode verwendet werden.
  45. </para>
  46. <example id="zend.registry.using.retrieving.example">
  47. <title>Beispiel der Verwendung der get() Methode</title>
  48. <programlisting role="php"><![CDATA[
  49. $value = Zend_Registry::get('index');
  50. ]]></programlisting>
  51. </example>
  52. <para>
  53. Die <code>getInstance()</code> Methode gibt ein Singleton Registry Objekt zurück.
  54. Dieses Registry Objekt ist durchsuchbar, und erlaubt es auf alle in der Registry gespeicherten
  55. Werte einfach zuzugreifen.
  56. </para>
  57. <example id="zend.registry.using.retrieving.example-iterating">
  58. <title>Beispiel des Durchsuchens der Registry</title>
  59. <programlisting role="php"><![CDATA[
  60. $registry = Zend_Registry::getInstance();
  61. foreach ($registry as $index => $value) {
  62. echo "Registry Index $index enthält:\n";
  63. var_dump($value);
  64. }
  65. ]]></programlisting>
  66. </example>
  67. </sect2>
  68. <sect2 id="zend.registry.using.constructing">
  69. <title>Erstellen eines Registry Objektes</title>
  70. <para>
  71. Zusätzlich zur Verwendung der statischen Registry über die statischen Methoden,
  72. kann eine Instanz direkt erzeugt werden und als Objekt verwendet werden.
  73. </para>
  74. <para>
  75. Die Registry Instanz die durch die statischen Methoden verwendet wird,
  76. ist einfach eine solche Instanz. Es ist eine Vereinfachung die statisch
  77. gespeichert ist damit Sie von überall innerhalb einer Anwendung verwendet
  78. werden kann.
  79. </para>
  80. <para>
  81. Der traditionelle <code>new</code> Operator kann verwendet werden um
  82. <classname>Zend_Registry</classname> zu initiieren. Das Initiieren von <classname>Zend_Registry</classname>
  83. mit seinem Konstruktor initiiert auch die Einträge in der Registry einfach durch die
  84. Verwendung eines assoziativen Arrays als Argument.
  85. </para>
  86. <example id="zend.registry.using.constructing.example">
  87. <title>Beispiel für das Erstellen einer Registry</title>
  88. <programlisting role="php"><![CDATA[
  89. $registry = new Zend_Registry(array('index' => $value));
  90. ]]></programlisting>
  91. </example>
  92. <para>
  93. Sobald so ein <classname>Zend_Registry</classname> Objekt initiiert wurde, kann es durch den
  94. Aufruf irgendeiner Array Objektmethode verwendet werden, oder indem es als
  95. Singleton Instanz für <classname>Zend_Registry</classname> mit der statischen Methode
  96. <code>setInstance()</code> gesetzt wird.
  97. </para>
  98. <example id="zend.registry.using.constructing.example-setinstance">
  99. <title>Beispiel der Initialisierung der Singleton Registry</title>
  100. <programlisting role="php"><![CDATA[
  101. $registry = new Zend_Registry(array('index' => $value));
  102. Zend_Registry::setInstance($registry);
  103. ]]></programlisting>
  104. </example>
  105. <para>
  106. Die <code>setInstance()</code> Methode wirft eine <classname>Zend_Exception</classname> wenn die
  107. statische Registry bereits initialisiert wurde.
  108. </para>
  109. </sect2>
  110. <sect2 id="zend.registry.using.array-access">
  111. <title>Auf die Registry als Array zugreifen</title>
  112. <para>
  113. Wenn mehrere Werte gesetzt oder gelesen werden sollen, kann es einfacher
  114. sein auf die Registry in Array Schreibweise zuzugreifen.
  115. </para>
  116. <example id="zend.registry.using.array-access.example">
  117. <title>Beispiel eines Array-zugriffs</title>
  118. <programlisting role="php"><![CDATA[
  119. $registry = Zend_Registry::getInstance();
  120. $registry['index'] = $value;
  121. var_dump( $registry['index'] );
  122. ]]></programlisting>
  123. </example>
  124. </sect2>
  125. <sect2 id="zend.registry.using.array-object">
  126. <title>Zugriff auf die Registry als Objekt</title>
  127. <para>
  128. Manchmal ist es einfacher auf die Registry in einer Objekt-Orientierten
  129. Art und Weise zuzugreifen, durch Verwendung von Indexnamen als Objekt Eigenschaften.
  130. Man muß das Registry Objekt mit der <code>ArrayObject::ARRAY_AS_PROPS</code>
  131. Option erstellen und die statische Instanz initialisieren um diese Funktionalität
  132. einzuschalten.
  133. <note>
  134. <para>
  135. Man muß die <code>ArrayObject::ARRAY_AS_PROPS</code> Option setzen
  136. <emphasis>bevor</emphasis> auf die statische Registry das erste Mal
  137. zugegriffen wird.
  138. </para>
  139. </note>
  140. </para>
  141. <warning>
  142. <title>Bekannte Probleme mit der ArrayObject::ARRAY_AS_PROPS Option</title>
  143. <para>
  144. Einige Versionen von PHP sind bekanntermaßen sehr fehlerhaft wenn die Registry mit der
  145. <code>ArrayObject::ARRAY_AS_PROPS</code> Option verwendet wird.
  146. </para>
  147. </warning>
  148. <example id="zend.registry.using.array-object.example">
  149. <title>Beispiel eines Objektzugriffs</title>
  150. <programlisting role="php"><![CDATA[
  151. // In der Anwendungs Bootstrap Datei:
  152. $registry = new Zend_Registry(array(), ArrayObject::ARRAY_AS_PROPS)
  153. Zend_Registry::setInstance($registry);
  154. $registry->tree = 'Apfel';
  155. .
  156. .
  157. .
  158. // In einer anderen Funktion, irgendwo in der Anwendung:
  159. $registry = Zend_Registry::getInstance();
  160. echo $registry->tree; // Gibt "Apfel" aus
  161. $registry->index = $value;
  162. var_dump($registry->index);
  163. ]]></programlisting>
  164. </example>
  165. </sect2>
  166. <sect2 id="zend.registry.using.isset">
  167. <title>Abfragen ob ein Index existiert</title>
  168. <para>
  169. Um herauszufinden ob ein bestimmter Index in der Registry gesetzt wurde,
  170. kann die statische Methode <code>isRegistered()</code> verwendet werden.
  171. </para>
  172. <example id="zend.registry.using.isset.example-isregistered">
  173. <title>Beispiel der Verwendung der isRegistered() Methode</title>
  174. <programlisting role="php"><![CDATA[
  175. if (Zend_Registry::isRegistered($index)) {
  176. $value = Zend_Registry::get($index);
  177. }
  178. ]]></programlisting>
  179. </example>
  180. <para>
  181. Um herauszufinden ob ein bestimmter Index in einem Registry Array oder Objekt
  182. einen Wert hat kann die <code>isset()</code> Methode verwendet werden, wie bei einem
  183. gewöhnlichen Array.
  184. </para>
  185. <example id="zend.registry.using.isset.example-isset">
  186. <title>Beispiel der Verwendung der isset() Methode</title>
  187. <programlisting role="php"><![CDATA[
  188. $registry = Zend_Registry::getInstance();
  189. // Verwendung der Array Syntax
  190. if (isset($registry['index'])) {
  191. var_dump( $registry['index'] );
  192. }
  193. // Verwendung der Objekt Syntax
  194. if (isset($registry->index)) {
  195. var_dump( $registry->index );
  196. }
  197. ]]></programlisting>
  198. </example>
  199. </sect2>
  200. <sect2 id="zend.registry.using.subclassing">
  201. <title>Erweitern der Registry</title>
  202. <para>
  203. Die statische Registry ist eine Instanz der Klasse <classname>Zend_Registry</classname>.
  204. Wenn Funktionalität zur Registry hinzugefügt werden soll, sollte eine
  205. Klasse erstellt werden die <classname>Zend_Registry</classname> erweitert und dann kann diese
  206. spezielle Klasse definiert werden um das Singleton in der statische Registry zu initiieren.
  207. Die statische Methode <code>setClassName()</code> kann verwendet
  208. werden um die Klasse zu definieren.
  209. <note>
  210. <para>
  211. Diese Klasse muß eine Unterklasse von <classname>Zend_Registry</classname> sein.
  212. </para>
  213. </note>
  214. </para>
  215. <example id="zend.registry.using.subclassing.example">
  216. <title>Beispiel des Definierens des Singleton Registry Klassennamens</title>
  217. <programlisting role="php"><![CDATA[
  218. Zend_Registry::setClassName('Meine_Registry');
  219. Zend_Registry::set('index', $value);
  220. ]]></programlisting>
  221. </example>
  222. <para>
  223. Die Registry wirft eine <classname>Zend_Exception</classname> wenn man versucht den Klassennamen
  224. zu setzen nachdem die Registry das erste Mal verwendet wurde. Es ist deshalb
  225. notwendig den Klassennamen für die statische Registry in der Bootstrap
  226. Datei der Anwendung zu definieren.
  227. </para>
  228. </sect2>
  229. <sect2 id="zend.registry.using.unsetting">
  230. <title>Entfernen der statischen Registry</title>
  231. <para>
  232. Obwohl es normalerweise nicht notwendig ist, kann die Singleton Instanz
  233. der Registry entfernt werden. Die statische Methode
  234. <code>_unsetInstance()</code> verwendet werden, um das zu tun.
  235. </para>
  236. <warning>
  237. <title>Risiko des Datenverlustes</title>
  238. <para>
  239. Wenn <code>_unsetInstance()</code> verwendet wird,
  240. werden alle Daten in der statischen Registry verworfen und können
  241. nicht wiederhergestellt werden.
  242. </para>
  243. </warning>
  244. <para>
  245. Diese Methode kann zum Beispiel verwendet werden, wenn
  246. <code>setInstance()</code> oder <code>setClassName()</code> nach der
  247. Initialisierung des Singleton Registry Objektes verwendet werden soll.
  248. Entfernen der Singleton Instanz erlaubt die Benutzung dieser Methoden
  249. selbst nachdem das Singleton Registry Objekt gesetzt wurde. Die Verwendung
  250. von <classname>Zend_Registry</classname> auf diese Weise ist für typische Anwendungen
  251. und Umgebungen nicht empfohlen.
  252. </para>
  253. <example id="zend.registry.using.unsetting.example">
  254. <title>Beispiel der Verwendung der _unsetInstance() Methode</title>
  255. <programlisting role="php"><![CDATA[
  256. Zend_Registry::set('index', $value);
  257. Zend_Registry::_unsetInstance();
  258. // Ändern der Klasse
  259. Zend_Registry::setClassName('Meine_Registry');
  260. Zend_Registry::set('index', $value);
  261. ]]></programlisting>
  262. </example>
  263. </sect2>
  264. </sect1>
  265. <!--
  266. vim:se ts=4 sw=4 et:
  267. -->