Zend_Auth_Adapter_OpenId.xml 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.auth.adapter.openid">
  5. <title>Open ID Authentifikation</title>
  6. <sect2 id="zend.auth.adapter.openid.introduction">
  7. <title>Einführung</title>
  8. <para>
  9. Der <classname>Zend_Auth_Adapter_OpenId</classname> Adapter kann verwendet werden um
  10. Benutzer durch Verwendung eines entfernten OpenID Servers zu authentifizieren. Diese
  11. Authentifizierungsmethode nimmt an das Benutzer nur ihre OpenID Identität an die Web
  12. Anwendung übermitteln. Dann werden Sie zu Ihrem OpenID Anbieter umgeleitet um die
  13. Eigentümerschaft der Identität mit Hilfe eines Passwortes oder einer anderen Methode zu
  14. prüfen. Dieses Passwort wird der Web Anwendung nie bekannt gegeben.
  15. </para>
  16. <para>
  17. Die OpenID Identität ist nur eine URL die auf eine Webseite mit entsprechenden
  18. Informationen über den Benutzer und spezielle Tags verweist welche beschreiben welcher
  19. Server verwendet werden soll und welche Identität dort zu übermitteln ist. Mehr über
  20. OpenID kann auf der <ulink url="http://www.openid.net/">offiziellen OpenID Site</ulink>
  21. nachgelesen werden.
  22. </para>
  23. <para>
  24. Die <classname>Zend_Auth_Adapter_OpenId</classname> Klasse umgibt die
  25. <classname>Zend_OpenId_Consumer</classname> Komponente welche das OpenID
  26. Authentifizierungs Protokoll selbst implementiert.
  27. </para>
  28. <note>
  29. <para>
  30. <classname>Zend_OpenId</classname> hat Vorteile davon wenn die
  31. <ulink url="http://php.net/gmp">GMP Erweiterung</ulink> vorhanden ist. Es sollte
  32. Angedacht werden die GMP Erweiterung für eine bessere Performance einzuschalten wenn
  33. <classname>Zend_Auth_Adapter_OpenId</classname> verwendet wird.
  34. </para>
  35. </note>
  36. </sect2>
  37. <sect2 id="zend.auth.adapter.openid.specifics">
  38. <title>Spezielles</title>
  39. <para>
  40. Wie in diesem Fall für alle <classname>Zend_Auth</classname> Adapter, implementiert die
  41. <classname>Zend_Auth_Adapter_OpenId</classname> Klasse das
  42. <classname>Zend_Auth_Adapter_Interface</classname>, welches nur eine Methode definiert:
  43. <code>authenticate()</code>. Diese Methode führt die Authentifizierung selbst durch,
  44. allerdings muß das Objekt vor dem Aufruf vorbereitet werden. So eine Vorbereitung des
  45. Adapters beinhaltet das Setzen der OpenID Identität und einige andere
  46. <classname>Zend_OpenId</classname> spezifische Optionen.
  47. </para>
  48. <para>
  49. Trotzdem, im Gegensatz zu anderen <classname>Zend_Auth</classname> Adaptern führt
  50. <classname>Zend_Auth_Adapter_OpenId</classname> Authentifizierungen an einem externen
  51. Server durch und das wird in zwei separaten HTTP Anfragen getan. Deswegen muß
  52. <classname>Zend_Auth_Adapter_OpenId::authenticate()</classname> zweimal aufgerufen
  53. werden. Beim ersten Aufruf wird die Methode nichts zurückgeben, aber den Benutzer zu
  54. seinem OpenID Server umleiten. Dann, nachdem der Benutzer auf dem entfernten Server
  55. authentifiziert ist wird dieser wieder zurück umleiten und das Skript muß für diese
  56. zweite Anfrage <classname>Zend_Auth_Adapter_OpenId::authenticate()</classname> nochmals
  57. aufrufen um die Signatur zu prüfen, welche mit der umgeleiteten Anfrage vom Server
  58. geschickt wird, und den Authentifikationsprozess zu beenden. Bei diesem zweiten Aufruf
  59. wird wie erwartet ein <classname>Zend_Auth_Result</classname> Objekt zurückgegeben.
  60. </para>
  61. <para>
  62. Das folgende Beispiel zeigt die Verwendung von
  63. <classname>Zend_Auth_Adapter_OpenId</classname>. Wie vorher erwähnt wird die
  64. <classname>Zend_Auth_Adapter_OpenId::authenticate()</classname> Methode zweimal
  65. aufgerufen. Das erste Mal, ist nachdem der Benutzer das HTML Formular übermittelt hat
  66. und <code>$_POST['openid_action']</code> auf <code>"login"</code> gesetzt wurde, und das
  67. zweite Mal nach der HTTP Umleitung vom OpenID Server wenn
  68. <code>$_GET['openid_mode']</code> oder <code>$_POST['openid_mode']</code> gesetzt wurde.
  69. </para>
  70. <programlisting language="php"><![CDATA[
  71. $status = "";
  72. $auth = Zend_Auth::getInstance();
  73. if ((isset($_POST['openid_action']) &&
  74. $_POST['openid_action'] == "login" &&
  75. !empty($_POST['openid_identifier'])) ||
  76. isset($_GET['openid_mode']) ||
  77. isset($_POST['openid_mode'])) {
  78. $result = $auth->authenticate(
  79. new Zend_Auth_Adapter_OpenId(@$_POST['openid_identifier']));
  80. if ($result->isValid()) {
  81. $status = "Sie sind angemeldet als "
  82. . $auth->getIdentity()
  83. . "<br>\n";
  84. } else {
  85. $auth->clearIdentity();
  86. foreach ($result->getMessages() as $message) {
  87. $status .= "$message<br>\n";
  88. }
  89. }
  90. } else if ($auth->hasIdentity()) {
  91. if (isset($_POST['openid_action']) &&
  92. $_POST['openid_action'] == "logout") {
  93. $auth->clearIdentity();
  94. } else {
  95. $status = "Sie sind angemeldet als "
  96. . $auth->getIdentity()
  97. . "<br>\n";
  98. }
  99. }
  100. ?>
  101. <html><body>
  102. <?php echo htmlspecialchars($status);?>
  103. <form method="post"><fieldset>
  104. <legend>OpenID Login</legend>
  105. <input type="text" name="openid_identifier" value="">
  106. <input type="submit" name="openid_action" value="login">
  107. <input type="submit" name="openid_action" value="logout">
  108. </fieldset></form></body></html>
  109. */
  110. ]]></programlisting>
  111. <para>
  112. Man kann den OpenID Authentifizierungs Prozess auf verschiedenen Wegen anzupassen. Man
  113. kann,zum Bespiel, die Umleitung des OpenID Servers auf eine eigene Seite erhalten, indem
  114. der "root" der Webseite spezifiziert wird und ein eigener
  115. <classname>Zend_OpenId_Consumer_Storage</classname> oder
  116. <classname>Zend_Controller_Response</classname> verwendet wird. Man kann auch eine
  117. einfache Registrierungserweiterung verwenden um Informationen über den Benutzer vom
  118. OpenID Server zu erhalten. Alle diese Möglichkeiten werden detailierter im Kapitel
  119. <classname>Zend_OpenId_Consumer</classname> beschrieben.
  120. </para>
  121. </sect2>
  122. </sect1>
  123. <!--
  124. vim:se ts=4 sw=4 et:
  125. -->