Zend_Oauth-GettingStarted.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect2 id="zend.oauth.introduction.getting-started">
  5. <title>Beginnen</title>
  6. <para>
  7. Da das OAuth Protokoll jetzt erklärt wurde sehen wir uns ein einfaches Beispiel mit
  8. Quellcode an. Unser neuer Konsument wird Twitter Statusübertragungen verwenden. Um das tun
  9. zu können muss er bei Twitter registriert sein um einen OAuth Konsumentenschlüssel und ein
  10. Konsumentengeheimnis zu empfangen. Diese werden verwendet um einen Zugriffstoken zu
  11. erhalten bevor wir die Twitter <acronym>API</acronym> verwenden um eine Statusmeldung zu
  12. schicken.
  13. </para>
  14. <para>
  15. Angenommen wir haben einen Schlüssel und ein Geheimnis bekommen, dann können wir den OAuth
  16. Workflow starten indem eine <classname>Zend_Oauth_Consumer</classname> Instanz wie folgt
  17. eingerichtet und eine Konfiguration übergeben wird (entweder ein Array oder ein
  18. <classname>Zend_Config</classname> Objekt).
  19. </para>
  20. <programlisting language="php"><![CDATA[
  21. $config = array(
  22. 'callbackUrl' => 'http://example.com/callback.php',
  23. 'siteUrl' => 'http://twitter.com/oauth',
  24. 'consumerKey' => 'gg3DsFTW9OU9eWPnbuPzQ',
  25. 'consumerSecret' => 'tFB0fyWLSMf74lkEu9FTyoHXcazOWpbrAjTCCK48A'
  26. );
  27. $consumer = new Zend_Oauth_Consumer($config);
  28. ]]></programlisting>
  29. <para>
  30. callbackUrl ist die URI von der wir wollen das Sie Twitter von unserem Server anfragt wenn
  31. Informationen gesendet werden. Wir sehen uns das später an. siteUrl ist die Basis URL der
  32. OAuth <acronym>API</acronym> Endpunkte von Twitter. Die komplette Liste der Endpunkt enthält
  33. http://twitter.com/oauth/request_token, http://twitter.com/oauth/access_token und
  34. http://twitter.com/oauth/authorize. Die grundsätzliche siteUrl verwendet eine Konvention
  35. welche auf diese drei OAuth Endpunkte verweist (als Standard) um einen Anfragetoken, den
  36. Zugriffstoken oder die Authorisierung zu erhalten. Wenn sich der aktuelle Endpunkt eines
  37. beliebigen Services vom Standardset unterscheidet, dann können diese drei URIs separat
  38. gesetzt werden indem die Methoden <methodname>setRequestTokenUrl()</methodname>,
  39. <methodname>setAccessTokenUrl()</methodname>, und
  40. <methodname>setAuthorizeUrl()</methodname>, oder die Konfigurationsfelder requestTokenUrl,
  41. accessTokenUrl und authorizeUrl verwendet werden.
  42. </para>
  43. <para>
  44. consumerKey und consumerSecret werden von Twitter empfangen wenn sich die eigene Anwendung
  45. für den OAuth Zugriff registriert. Das wird auch bei jedem OAuth aktivierten Service so
  46. angewendet, so dass jeder einen Schlüssel und ein Geheimnis für die eigene Anwendung
  47. anbietet.
  48. </para>
  49. <para>
  50. Alle diese Konfigurationsoptionen müssen durch Verwendung von Methodenaufrufen gesetzt
  51. werden indem Sie einfach von callbackUrl auf setCallbackUrl() konvertiert werden.
  52. </para>
  53. <para>
  54. Zusätzlich sollte beachtet werden das verschiedene andere Konfigurationswerte nicht explizit
  55. verwendet werden: requestMethod und requestScheme. Standardmäßig sendet
  56. <classname>Zend_Oauth_Consumer</classname> Anfragen als POST (ausgenommen bei einer
  57. Weiterleitung welche <constant>GET</constant> verwendet). Der konsumierende Client (siehe
  58. später) enthält auch seine Authorisierung in Art eines Headers. Einige Services können, zu
  59. Ihrer Diskretion, Alternativen benötigen. Man kann requestMethod (welche standardmäßig
  60. Zend_Oauth::POST ist) zum Beispiel auf Zend_Oauth::GET zurückgesetzt, und requestScheme von
  61. seinem Standardwert Zend_Oauth::REQUEST_SCHEME_HEADER entweder auf
  62. Zend_Oauth::REQUEST_SCHEME_POSTBODY oder auf Zend_Oauth::REQUEST_SCHEME_QUERYSTRING.
  63. Typischerweise sollten die Standardwerte bis auf ein paar bestimmte Ausnahmen problemlos
  64. funktionieren. Für Details sehen Sie bitte in die Dokumentation des Service Providers.
  65. </para>
  66. <para>
  67. Der zweite Teil der Anpassung definiert wie <acronym>HMAC</acronym> arbeitet wenn es für
  68. alle Anfragen berechnet und verglichen wird. Das wird durch Verwendung des
  69. Konfigurationsfeldes signatureMethod oder durch
  70. <methodname>setSignatureMethod()</methodname> konfiguriert. Standardmäßig ist es HMAC-SHA1.
  71. Man kann es auch auf die vom Provider bevorzugte Methode setzen inklusive RSA-SHA1. Für
  72. RSA-SHA1 sollte man die privaten und öffentlichen RSA Schlüssel über die
  73. Konfigurationsfelder rsaPrivateKey und rsaPublicKey oder die Methoden
  74. <methodname>setRsaPrivateKey()</methodname> und <methodname>setRsaPublicKey()</methodname>
  75. konfigurieren.
  76. </para>
  77. <para>
  78. Der erste Teil des OAuth Workflows holt sich einen Anfragetoken. Das wird bewerkstelligt
  79. indem folgendes verwendet wird:
  80. </para>
  81. <programlisting language="php"><![CDATA[
  82. $config = array(
  83. 'callbackUrl' => 'http://example.com/callback.php',
  84. 'siteUrl' => 'http://twitter.com/oauth',
  85. 'consumerKey' => 'gg3DsFTW9OU9eWPnbuPzQ',
  86. 'consumerSecret' => 'tFB0fyWLSMf74lkEu9FTyoHXcazOWpbrAjTCCK48A'
  87. );
  88. $consumer = new Zend_Oauth_Consumer($config);
  89. // Holt den Anfragetoken
  90. $token = $consumer->getRequestToken();
  91. ]]></programlisting>
  92. <para>
  93. Der neue Anfragetoken (eine Instanz von <classname>Zend_Oauth_Token_Request</classname>)
  94. ist nicht authorisiert. Um Ihn mit einem authorisierten Token zu wechseln mit dem wir auf
  95. die Twitter <acronym>API</acronym> zugreifen können, muss Ihn der Benutzer authorisieren.
  96. Wir bewerkstelligen das indem der Benutzer auf den Authorisierungsendpunkt von Twitter
  97. umgeleitet wird:
  98. </para>
  99. <programlisting language="php"><![CDATA[
  100. $config = array(
  101. 'callbackUrl' => 'http://example.com/callback.php',
  102. 'siteUrl' => 'http://twitter.com/oauth',
  103. 'consumerKey' => 'gg3DsFTW9OU9eWPnbuPzQ',
  104. 'consumerSecret' => 'tFB0fyWLSMf74lkEu9FTyoHXcazOWpbrAjTCCK48A'
  105. );
  106. $consumer = new Zend_Oauth_Consumer($config);
  107. // Holt den Anfragetoken
  108. $token = $consumer->getRequestToken();
  109. // Den token im Speicher fixieren
  110. $_SESSION['TWITTER_REQUEST_TOKEN'] = serialize($token);
  111. // Den Benutzer umleiten
  112. $consumer->redirect();
  113. ]]></programlisting>
  114. <para>
  115. Der Benutzer wird jetzt auf Twitter umgeleitet. Er wird gefragt den Anfragetoken zu
  116. authorisieren, welcher an den Anfragestring der umgeleiteten URI angehängt ist. Angenommen
  117. er akzeptiert und vervollständigt die Authorisierung, dann wird er wieder umgeleitet. Dieses
  118. Mal auf unsere Callback URL die vorher gesetzt wurde (Beachte das die Callback URL auch in
  119. Twitter registriert wurde als wir unsere Anwendung registriert haben).
  120. </para>
  121. <para>
  122. Bevor der Benutzer umgeleitet wird, sollten wir den Anfragetoken im Speicher fixieren. Der
  123. Einfachheit halber verwenden wir nur die Session des Benutzer, aber man kann sehr einfach
  124. eine Datenbank für den gleichen Zweck verwenden, solange der Anfragetoken mit dem aktuellen
  125. Benutzer verbunden bleibt, damit er empfangen werden kann wenn dieser zu unserer Anwendung
  126. zurückkommt.
  127. </para>
  128. <para>
  129. Die umgeleitete URI von Twitter enthält einen authorisierten Zugriffstoken. Wir können Code
  130. einbauen um diesen Zugriffstoken wie folgt herauszuschneiden - dieser Sourcecode würde im
  131. ausgeführten Code unserer Callback URI existieren. Sobald er herausgeschnitten wurde können
  132. wir den vorherigen Anfragetoken entfernen, und statt dessen den Zugriffstoken für die
  133. zukünftige Verendung mit der <acronym>API</acronym> von Twitter fixieren. Nochmals, wir
  134. fixieren einfach die Session des Benutzer, aber in Wirklichkeit kann ein Zugriffstoken eine
  135. lange Lebenszeit haben, und sollte deshalb wirklich in einer Datenbank abgespeichert werden.
  136. </para>
  137. <programlisting language="php"><![CDATA[
  138. $config = array(
  139. 'callbackUrl' => 'http://example.com/callback.php',
  140. 'siteUrl' => 'http://twitter.com/oauth',
  141. 'consumerKey' => 'gg3DsFTW9OU9eWPnbuPzQ',
  142. 'consumerSecret' => 'tFB0fyWLSMf74lkEu9FTyoHXcazOWpbrAjTCCK48A'
  143. );
  144. $consumer = new Zend_Oauth_Consumer($config);
  145. if (!empty($_GET) && isset($_SESSION['TWITTER_REQUEST_TOKEN'])) {
  146. $token = $consumer->getAccessToken(
  147. $_GET,
  148. unserialize($_SESSION['TWITTER_REQUEST_TOKEN'])
  149. );
  150. $_SESSION['TWITTER_ACCESS_TOKEN'] = serialize($token);
  151. // Jetzt da wir den Zugriffstoken haben können wir den Anfragetoken löschen
  152. $_SESSION['TWITTER_REQUEST_TOKEN'] = null;
  153. } else {
  154. // Fehlgeschlagene Anfrage? Ein Gauner versucht etwas?
  155. exit('Ungültige Callback Anfrage. Oops. Entschuldigung.');
  156. }
  157. ]]></programlisting>
  158. <para>
  159. Erfolg! Wir haben einen authorisierten Zugriffstoken - zu dieser Zeit verwenden wir schon
  160. die <acronym>API</acronym> von Twitter. Da dieser Zugriffstoken bei jeder einzelnen
  161. <acronym>API</acronym> Anfrage enthalten sein muss, bietet
  162. <classname>Zend_Oauth_Consumer</classname> einen fix-fertigen <acronym>HTTP</acronym> Client
  163. an (eine Subklasse von <classname>Zend_Http_Client</classname>) welcher entweder für sich
  164. verwendet werden, oder der als eigener <acronym>HTTP</acronym> Client an eine andere
  165. Bibliothek oder Komponente übergeben werden kann. Hier ist ein Beispiel für die
  166. eigenständige Verwendung. Das kann von überall aus der Anwendung heraus getan werden,
  167. solange man Zugriff auf die OAuth Konfiguration hat, und den endgültigen authorisierten
  168. Zugriffstoken empfangen kann.
  169. </para>
  170. <programlisting language="php"><![CDATA[
  171. $config = array(
  172. 'callbackUrl' => 'http://example.com/callback.php',
  173. 'siteUrl' => 'http://twitter.com/oauth',
  174. 'consumerKey' => 'gg3DsFTW9OU9eWPnbuPzQ',
  175. 'consumerSecret' => 'tFB0fyWLSMf74lkEu9FTyoHXcazOWpbrAjTCCK48A'
  176. );
  177. $statusMessage = 'Ich sende über Twitter und verwende Zend_Oauth!';
  178. $token = unserialize($_SESSION['TWITTER_ACCESS_TOKEN']);
  179. $client = $token->getHttpClient($configuration);
  180. $client->setUri('http://twitter.com/statuses/update.json');
  181. $client->setMethod(Zend_Http_Client::POST);
  182. $client->setParameterPost('status', $statusMessage);
  183. $response = $client->request();
  184. $data = Zend_Json::decode($response->getBody());
  185. $result = $response->getBody();
  186. if (isset($data->text)) {
  187. $result = 'true';
  188. }
  189. echo $result;
  190. ]]></programlisting>
  191. <para>
  192. Als Notiz zum eigenen Client, kann dieser an den meisten Services von Zend Framework
  193. übergeben werden, oder an andere Klassen welche <classname>Zend_Http_Client</classname>
  194. verwenden um damit den Standardclient zu ersetzen welcher andernfalls verwendet werden
  195. würde.
  196. </para>
  197. </sect2>