Zend_Auth.xml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15156 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.auth.introduction">
  5. <title>Einführung</title>
  6. <para>
  7. <classname>Zend_Auth</classname> bietet eine API für das Authentifizieren und enthält konkrete
  8. Authentifizierungs-Adapter für übliche Use Case Szenarien.
  9. </para>
  10. <para>
  11. <classname>Zend_Auth</classname> behandelt nur die <emphasis role="strong">Authentifizierung</emphasis>
  12. und nicht die <emphasis role="strong">Authorisierung</emphasis>. Authentifizierung ist lose
  13. definiert als das Ermitteln ob eine Entität aktuell das ist was Sie vorgibt zu sein (z.B.
  14. Identifizierung), basierend auf einem Set von Zeugnissen. Authorisierung, der Prozess des
  15. Entscheidens ob es einer Entität erlaubt wird auf andere Entitäten Zugriff zu erhalten,
  16. oder um auf diesen Operationen durchzuführen, ist ausserhalb der Möglichkeit von
  17. <classname>Zend_Auth</classname>. Für weitere Informationen über Authorisierung und Zugriffskontrolle
  18. mit dem Zend Framework, sollte <link linkend="zend.acl"><classname>Zend_Acl</classname></link>
  19. angeschaut werden.
  20. </para>
  21. <note>
  22. <para>
  23. Die <classname>Zend_Auth</classname> Klasse implementiert das Singleton Pattern - nur eine Instanz der
  24. Klasse ist vorhanden - durch Ihre statische <code>getInstance()</code> Methode. Das bedeutet das
  25. die Verwendung des <code>new</code> Operators und des <code>clone</code> Keywords mit der
  26. <classname>Zend_Auth</classname> Klasse nicht funktioniert; stattdessen muß <classname>Zend_Auth::getInstance()</classname>
  27. verwendet werden.
  28. </para>
  29. </note>
  30. <sect2 id="zend.auth.introduction.adapters">
  31. <title>Adapter</title>
  32. <para>
  33. Ein <classname>Zend_Auth</classname> Adapter wird verwendet um sich gegenüber einem speziellen
  34. Typ von Authentifizierungs Services zu authentifizieren, wie LDAP, RDBMS, oder
  35. Datei-basierenden Speichern. Verschiedene Adapter besitzen leicht unterschiedliche
  36. Optionen und Verhaltensweisen, aber einige grundlegende Dinge sind für
  37. Authentifizierungs Adapter üblich. Zum Beispiel das die Authentifizierung Zeugnisse
  38. akzeptiert werden (enthält auch vorgegebene Identitäten), das Abfragen am
  39. Authentifizierungsservice durchgeführt werden, und das Ergebnisse zurückgegeben werden,
  40. sind für <classname>Zend_Auth</classname> Adapter üblich.
  41. </para>
  42. <para>
  43. Jede <classname>Zend_Auth</classname> Adapter Klasse implementiert <classname>Zend_Auth_Adapter_Interface</classname>. Dieses
  44. Interface definiert eine Methode, <code>authenticate()</code>, die eine Adapter Klasse implementieren
  45. muß um eine Authentifizierungsanfrage auszuführen. Jede Adapter Klasse muß vorher vorbereitet sein
  46. bevor <code>authenticate()</code> aufgerufen wird. Diese Vorbereitung des Adapters enthält das
  47. Setzen der Zeugnisse (z.B. Benutzername und Passwort) und die Definition von Werten für
  48. Adapter spezifische Konfigurationoptionen, wie Datenbank Verbindungsdaten für einen Datenbank
  49. Tabellen Adapter.
  50. </para>
  51. <para>
  52. Das folgende ist ein Beispiel eines Authentifierungs-Adapters der einen Benutzernamen und ein
  53. Passwort für die Authentifizierung benötigt. Andere Details, wie zum Beispiel der
  54. Authentifizierungs-Service abgefragt wird, werden der Kürze halber ausgelassen:
  55. <programlisting role="php"><![CDATA[
  56. class MyAuthAdapter implements Zend_Auth_Adapter_Interface
  57. {
  58. /**
  59. * Setzt Benutzername und Passwort für die Authentifizierung
  60. *
  61. * @return void
  62. */
  63. public function __construct($username, $password)
  64. {
  65. // ...
  66. }
  67. /**
  68. * Führt einen Authentifizierungs-Versuch durch
  69. *
  70. * @throws Zend_Auth_Adapter_Exception Wenn die Authentifizierung nicht
  71. * durchgeführt wurde
  72. * @return Zend_Auth_Result
  73. */
  74. public function authenticate()
  75. {
  76. // ...
  77. }
  78. }
  79. ]]></programlisting>
  80. Wie im Docblock angegeben, muß <code>authenticate()</code> eine Instanz von
  81. <classname>Zend_Auth_Result</classname> (oder einer von <classname>Zend_Auth_Result</classname> abgeleiteten Klassen)
  82. zurückgeben. Wenn aus bestimmten Gründen eine Durchführung einer Authentifizierungs-Anfrage
  83. nicht möglich ist, sollte <code>authenticate()</code> eine Ausnahme werfen die von
  84. <classname>Zend_Auth_Adapter_Exception</classname> abgeleitet ist.
  85. </para>
  86. </sect2>
  87. <sect2 id="zend.auth.introduction.results">
  88. <title>Ergebnisse</title>
  89. <para>
  90. <classname>Zend_Auth</classname> Adapter geben eine Instanz von <classname>Zend_Auth_Result</classname> mit Hilfe von
  91. <code>authenticate()</code> zurück um die Ergebnisse des Authentifizierungs-Versuches darzustellen.
  92. Adapter veröffentlichen das <classname>Zend_Auth_Result</classname> Objekt bei der Erstellung, so das die
  93. folgenden vier Methoden ein grundsätzliches Set von Benutzerbezogenen Operationen bieten die
  94. für die Ergebnisse von <classname>Zend_Auth</classname> Adapter üblich sind:
  95. <itemizedlist>
  96. <listitem>
  97. <para>
  98. <code>isValid()</code> - Gibt true zurück wenn und nur wenn das Ergebnis einen
  99. erfolgreichen Authentifizierungs-Versuch repräsentiert
  100. </para>
  101. </listitem>
  102. <listitem>
  103. <para>
  104. <code>getCode()</code> - Gibt einen konstanten <classname>Zend_Auth_Result</classname>
  105. Identifizierer damit der Typ des Authentifizierungs-Fehlers, oder des Erfolgs der
  106. stattgefunden hat, ermittelt werden kann. Das kann in Situationen verwendet werden
  107. in denen der Entwickler die verschiedenen Ergebnistypen der Authentifizierung
  108. unterschiedlich behandeln will. Das erlaubt es dem Entwickler zum Beispiel detailierte
  109. Statistiken über die Authentifizierungs-Ergebnisse zu erhalten. Eine andere Verwendung
  110. dieses Features ist es spezielle, benutzerdefinierte Nachrichten anzubieten, um Benutzern
  111. eine bessere Usability zu ermöglichen, einfach dadurch das Entwickler dazu aufgerufen
  112. sind die Risiken solche defailierte Informationen Benutzern anzubieten, statt einer
  113. generellen Nachricht eines Authentifizierungs-Fehlers. Für weitere Informationen siehe
  114. die Notiz anbei.
  115. </para>
  116. </listitem>
  117. <listitem>
  118. <para>
  119. <code>getIdentity()</code> - Gibt die Identität des Authentifizierungs-Versuchs zurück
  120. </para>
  121. </listitem>
  122. <listitem>
  123. <para>
  124. <code>getMessages()</code> - Gibt ein Array von Nachrichten zurück nach einem
  125. fehlgeschlagenen Authentifizierungs-Versuch
  126. </para>
  127. </listitem>
  128. </itemizedlist>
  129. </para>
  130. <para>
  131. Ein Entwickler kann wünschen basierend auf dem Typ des Authentifizierungs-Ergebnisses zu
  132. verzweigen um spezialisiertere Operationen durchzuführen. Einige Operationen die für Entwickler
  133. nützlich sein können sind zum Beispiel das Sperren von Konten nachdem zu oft ein falsches
  134. Passwort angegeben wurde, das markieren von IP Adressen nachdem zuviele nicht existierende
  135. Identitäten angegeben wurden und das anbieten von speziellen, benutzerdefinierten Nachrichten
  136. für Authentifizierungs-Ergebnisse an den Benutzer. Die folgenden Ergebniscodes sind vorhanden:
  137. <programlisting role="php"><![CDATA[
  138. Zend_Auth_Result::SUCCESS
  139. Zend_Auth_Result::FAILURE
  140. Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND
  141. Zend_Auth_Result::FAILURE_IDENTITY_AMBIGUOUS
  142. Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID
  143. Zend_Auth_Result::FAILURE_UNCATEGORIZED
  144. ]]></programlisting>
  145. </para>
  146. <para>
  147. Das folgende Beispiel zeigt wie ein Entwickler anhand des Ergebniscodes verzweigen könnte:
  148. <programlisting role="php"><![CDATA[
  149. // Innerhalb von AuthController / loginAction
  150. $result = $this->_auth->authenticate($adapter);
  151. switch ($result->getCode()) {
  152. case Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND:
  153. /** Was wegen nicht existierender Identität machen **/
  154. break;
  155. case Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID:
  156. /** Was wegen ungültigen Zeugnissen machen **/
  157. break;
  158. case Zend_Auth_Result::SUCCESS:
  159. /** Was wegen erfolgreicher Authentifizierung machen **/
  160. break;
  161. default:
  162. /** Was wegen anderen Fehlern machen **/
  163. break;
  164. }
  165. ]]></programlisting>
  166. </para>
  167. </sect2>
  168. <sect2 id="zend.auth.introduction.persistence">
  169. <title>Dauerhafte Identitäten</title>
  170. <para>
  171. Eine Anfrage zu authentifizieren die Authentifizierungs Zeugnisse enthält ist per se nützlich,
  172. aber auch wichtig um die Authentifizierungs Identität bearbeiten zu können ohne das immer die
  173. Authentifizierungs Zeugnisse mit jeder Anfrage vorhanden sein müssen.
  174. </para>
  175. <para>
  176. Trotzdem ist HTTP ein statusloses Protokoll, und Techniken wie Cookies und Sessions wurden
  177. entwickelt um Stati über mehrere Anfragen hinweg in Server-seitigen Web Anwendungen zu
  178. erhalten.
  179. </para>
  180. <sect3 id="zend.auth.introduction.persistence.default">
  181. <title>Normale Persistenz in PHP Sessions</title>
  182. <para>
  183. Standardmäßig bietet <classname>Zend_Auth</classname> dauerhafte Speicherung der Identität eines
  184. erfolgreichen Authentifizierungs Versuches durch Verwendung der PHP Session. Bei einem
  185. erfolgreichen Authentifizierungs Versuch speichert <classname>Zend_Auth::authenticate()</classname>
  186. die Identität des Authentifizierungs Ergebnisses im persistenten Speicher. Solange die
  187. Konfiguration nicht verändert wird, verwendet <classname>Zend_Auth</classname> eine Speicherklasse
  188. die <classname>Zend_Auth_Storage_Session</classname> heißt und die im Gegenzug
  189. <link linkend="zend.session"><classname>Zend_Session</classname></link> verwendet. Eine eigene
  190. Klasse kann stattdessen verwendet werden, indem ein Objekt an
  191. <classname>Zend_Auth::setStorage()</classname> übergeben wird welches
  192. <classname>Zend_Auth_Storage_Interface</classname> implementiert.
  193. </para>
  194. <note>
  195. <para>
  196. Wenn das automatische persistente Speichern der Identität für einen bestimmten Anwendungsfall
  197. nicht anwendbar ist, können Entwickler trotzdem die <classname>Zend_Auth</classname> Klasse weiterhin
  198. verwenden statt direkt eine Adapterklasse anzusprechen.
  199. </para>
  200. </note>
  201. <example id="zend.auth.introduction.persistence.default.example">
  202. <title>Den Namensraum der Session ändern</title>
  203. <para>
  204. <classname>Zend_Auth_Storage_Session</classname> verwendet einen Session Namensraum von
  205. 'Zend_Auth'. Diese Namensraum kann überschrieben werden indem ein anderer
  206. Wert an den Konstruktor von <classname>Zend_Auth_Storage_Session</classname> übergeben wird, und dieser
  207. Wert wird intern an den Konstruktor von <classname>Zend_Session_Namespace</classname> weitergereicht.
  208. Das sollte vor einem Versuch einer Authentifizierung stattfinden da
  209. <classname>Zend_Auth::authenticate()</classname> die automatische Speicherung der Identität durchführt.
  210. <programlisting role="php"><![CDATA[
  211. // Eine Referenz zur Singleton Instanz von Zend_Auth speichern
  212. $auth = Zend_Auth::getInstance();
  213. // 'someNamespace' statt 'Zend_Auth' verwenden
  214. $auth->setStorage(new Zend_Auth_Storage_Session('someNamespace'));
  215. /**
  216. * @todo Den Auth Adapter $authAdapter erstellen
  217. */
  218. // Authentifizieren, das Ergebnis speichern, und die Identität bei Erfolg
  219. // persistent machen
  220. $result = $auth->authenticate($authAdapter);
  221. ]]></programlisting>
  222. </para>
  223. </example>
  224. </sect3>
  225. <sect3 id="zend.auth.introduction.persistence.custom">
  226. <title>Eigene Speicher implementieren</title>
  227. <para>
  228. Zeitweise wollen Entwickler einen anderen Speichermechanismus für Identitäten verwenden als
  229. es von <classname>Zend_Auth_Storage_Session</classname> angeboten wird. Für solche Fälle können
  230. Entwickler einfach <classname>Zend_Auth_Storage_Interface</classname> implementieren und eine
  231. Instanz der Klasse an <classname>Zend_Auth::setStorage()</classname> übergeben.
  232. </para>
  233. <example id="zend.auth.introduction.persistence.custom.example">
  234. <title>Eine eigene Speicher Klasse verwenden</title>
  235. <para>
  236. Um eine andere Speicherklasse für die Persistenz von Identitäten zu verwenden als sie
  237. durch <classname>Zend_Auth_Storage_Session</classname> angeboten wird, können Entwickler
  238. <classname>Zend_Auth_Storage_Interface</classname> implementieren:
  239. <programlisting role="php"><![CDATA[
  240. class MyStorage implements Zend_Auth_Storage_Interface
  241. {
  242. /**
  243. * Gibt true zurück wenn und nur wenn der Speicher leer ist
  244. *
  245. * @throws Zend_Auth_Storage_Exception Wenn es unmöglich ist festzustellen
  246. * ob der Speicher leer ist
  247. * @return boolean
  248. */
  249. public function isEmpty()
  250. {
  251. /**
  252. * @todo Implementierung
  253. */
  254. }
  255. /**
  256. * Gibt den Inhalt des Speichers zurück
  257. *
  258. * Das Verhalten ist undefiniert wenn der Speicher leer ist.
  259. *
  260. * @throws Zend_Auth_Storage_Exception Wenn das Lesen von Lesen vom Speicher
  261. * unmöglich ist
  262. * @return mixed
  263. */
  264. public function read()
  265. {
  266. /**
  267. * @todo Implementierung
  268. */
  269. }
  270. /**
  271. * Schreibt $contents in den Speicher
  272. *
  273. * @param mixed $contents
  274. * @throws Zend_Auth_Storage_Exception Wenn das Schreiben von $contents in
  275. * den Speicher unmöglich ist
  276. * @return void
  277. */
  278. public function write($contents)
  279. {
  280. /**
  281. * @todo Implementierung
  282. */
  283. }
  284. /**
  285. * Löscht die Intalte vom Speicher
  286. *
  287. * @throws Zend_Auth_Storage_Exception Wenn das Löschen der Inhalte vom
  288. * Speicher unmöglich ist
  289. * @return void
  290. */
  291. public function clear()
  292. {
  293. /**
  294. * @todo Implementierung
  295. */
  296. }
  297. }
  298. ]]></programlisting>
  299. </para>
  300. <para>
  301. Um diese selbstgeschriebene Speicherklasse zu verwenden wird
  302. <classname>Zend_Auth::setStorage()</classname> aufgerufen bevor eine Authentifizierungsanfrage
  303. stattfindet:
  304. <programlisting role="php"><![CDATA[
  305. // Zend_Auth anweisen das die selbstdefinierte Speicherklasse verwendet wird
  306. Zend_Auth::getInstance()->setStorage(new MyStorage());
  307. /**
  308. * @todo Den Auth Adapter $authAdapter erstellen
  309. */
  310. // Authentifizieren, das Ergebnis speichern, und die Identität bei Erfolg
  311. $result = Zend_Auth::getInstance()->authenticate($authAdapter);
  312. ]]></programlisting>
  313. </para>
  314. </example>
  315. </sect3>
  316. </sect2>
  317. <sect2 id="zend.auth.introduction.using">
  318. <title>Verwendung</title>
  319. <para>
  320. Es gibt zwei vorhandene Wege um <classname>Zend_Auth</classname> Adapter zu verwenden:
  321. <orderedlist>
  322. <listitem>
  323. <para>
  324. Indirekt durch <classname>Zend_Auth::authenticate()</classname>
  325. </para>
  326. </listitem>
  327. <listitem>
  328. <para>
  329. Direkt durch die <code>authenticate()</code> Methode des Adapters
  330. </para>
  331. </listitem>
  332. </orderedlist>
  333. </para>
  334. <para>
  335. Das folgende Beispiel zeigt wie ein <classname>Zend_Auth</classname> Adapter indirekt verwendet
  336. werden kann, durch die Verwendung der <classname>Zend_Auth</classname> Klasse:
  337. <programlisting role="php"><![CDATA[
  338. // Eine Referenz zur Singleton-Instanz von Zend_Auth erhalten
  339. $auth = Zend_Auth::getInstance();
  340. // Authentifizierungs Adapter erstellen
  341. $authAdapter = new MyAuthAdapter($username, $password);
  342. // Authentifizierungs Versuch, das Ergebnis abspeichern
  343. $result = $auth->authenticate($authAdapter);
  344. if (!$result->isValid()) {
  345. // Authentifizierung fehlgeschlagen; die genauen Gründe ausgeben
  346. foreach ($result->getMessages() as $message) {
  347. echo "$message\n";
  348. }
  349. } else {
  350. // Authentifizierung erfolgreich; die Identität ($username) wird in
  351. // der Session gespeichert
  352. // $result->getIdentity() === $auth->getIdentity()
  353. // $result->getIdentity() === $username
  354. }
  355. ]]></programlisting>
  356. </para>
  357. <para>
  358. Sobald die Authentifizierung in einer Anfrage durchgeführt wurde, so wie im obigen Beispiel,
  359. ist es sehr einfach zu Prüfen ob eine erfolgreich authentifizierte Identität existiert:
  360. <programlisting role="php"><![CDATA[
  361. $auth = Zend_Auth::getInstance();
  362. if ($auth->hasIdentity()) {
  363. // Identität existiert; auslesen
  364. $identity = $auth->getIdentity();
  365. }
  366. ]]></programlisting>
  367. </para>
  368. <para>
  369. Um eine Identität vom persistenten Speicher zu entfernen muß einfach die <code>clearIdentity()</code>
  370. Methode verwendet werden. Das würde typischerweise für die Implementierung einer "Abmelde" Operation
  371. in einer Anwendung Verwendung finden.
  372. <programlisting role="php"><![CDATA[
  373. Zend_Auth::getInstance()->clearIdentity();
  374. ]]></programlisting>
  375. </para>
  376. <para>
  377. Wenn die automatische Verwendung von persistenten Speichern für einen bestimmten Verwendungszweck
  378. unangebracht ist, kann ein Entwickler einfach die Verwendung der <classname>Zend_Auth</classname> Klasse
  379. umgehen, und eine Adapter Klasse direkt verwenden. Die direkte Verwendung einer Adapterklasse
  380. enthält das Konfigurieren und Vorbereiten eines Adapter Objektes und den Aufruf dessen
  381. <code>authenticate()</code> Methode. Adapter-spezifische Details werden in der Dokumentation
  382. jeden Adapters besprochen. Das folgende Beispeil verwendet <code>MyAuthAdapter</code> direkt:
  383. <programlisting role="php"><![CDATA[
  384. // Den Authentifizierungs Adapter erstellen
  385. $authAdapter = new MyAuthAdapter($username, $password);
  386. // Authentifizierungs Versuch, speichere das Ergebnis
  387. $result = $authAdapter->authenticate();
  388. if (!$result->isValid()) {
  389. // Authentifizierung fehlgeschlagen; die genauen Gründe ausgeben
  390. foreach ($result->getMessages() as $message) {
  391. echo "$message\n";
  392. }
  393. } else {
  394. // Authentifizierung erfolgreich
  395. // $result->getIdentity() === $username
  396. }
  397. ]]></programlisting>
  398. </para>
  399. </sect2>
  400. </sect1>
  401. <!--
  402. vim:se ts=4 sw=4 et:
  403. -->