Zend_Gdata_AuthSub.xml 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.gdata.authsub">
  5. <title>AuthSub による認証</title>
  6. <para>
  7. AuthSub を使用すると、ウェブアプリケーションで
  8. Google Data サービスへのアクセスのための認証ができるようになります。
  9. ユーザの認証情報を処理するコードを自分で書く必要はありません。
  10. </para>
  11. <para>
  12. Google Data AuthSub 認証についての詳細は、
  13. <ulink url="http://code.google.com/apis/accounts/AuthForWebApps.html">http://code.google.com/apis/accounts/AuthForWebApps.html</ulink>
  14. を参照ください。
  15. </para>
  16. <para>
  17. Google のドキュメントでは、ClientLogin 方式は
  18. "インストールするアプリケーション" に適しており、一方 AuthSub は
  19. "ウェブアプリケーション" に適しているとされています。
  20. これらの違いは、AuthSub はユーザとのやりとりが発生するということです。
  21. ブラウザのインターフェイスを用いて、リクエストのリダイレクトを行います。
  22. ClientLogin では PHP のコードでアカウント情報を提供します。
  23. ユーザが直接認証情報を入力する必要がなくなります。
  24. </para>
  25. <para>
  26. AuthSub の場合の認証情報は、ウェブアプリケーションのユーザが入力します。
  27. つまり、認証情報をユーザが知っておく必要があります。
  28. </para>
  29. <note>
  30. <title>登録されたアプリケーション</title>
  31. <para>
  32. <classname>Zend_Gdata</classname> は、現在はセキュアなトークンの使用をサポートしていません。
  33. なぜなら、デジタル証明書によるセキュアなトークンの取得を
  34. AuthSub 認証がサポートしていないからです。
  35. </para>
  36. </note>
  37. <sect2 id="zend.gdata.authsub.login">
  38. <title>AuthSub 認証済みの Http クライアントの作成</title>
  39. <para>
  40. あなたの作成した PHP アプリケーションで、認証を行う
  41. Google URL へのハイパーリンクを提供しなければなりません。そのためには
  42. 静的関数 <classname>Zend_Gdata_AuthSub::getAuthSubTokenUri()</classname>
  43. を使用します。この関数の引数には、あなたの作成した
  44. PHP アプリケーションの URL を指定します。それにより、ユーザ認証の後に
  45. Google からもとの場所にリダイレクトされるようになります。
  46. </para>
  47. <para>
  48. Google の認証サーバからアプリケーションに戻ってくる際に、
  49. <code>token</code> という名前の GET パラメータが設定されます。
  50. このパラメータの値は、認証されたアクセスに使用する single-use トークンとなります。
  51. このトークンを multi-use トークンに変換し、セッションに保存します。
  52. </para>
  53. <para>
  54. そしてそのトークンの値は使用して
  55. <classname>Zend_Gdata_AuthSub::getHttpClient()</classname>
  56. をコールします。この関数は <classname>Zend_Http_Client</classname>
  57. のインスタンスを返します。このインスタンスには適切なヘッダが設定されており、
  58. 後でこの Http クライアントを使用して送信したリクエストは認証済みのものとなります。
  59. </para>
  60. <para>
  61. 以下の例は、PHP のウェブアプリケーションのコードです。
  62. Google Calendar サービスに対する認証を行い、
  63. 認証済みの Http クライアントを使用して <classname>Zend_Gdata</classname>
  64. クライアントオブジェクトを作成します。
  65. </para>
  66. <programlisting role="php"><![CDATA[
  67. $my_calendar = 'http://www.google.com/calendar/feeds/default/private/full';
  68. if (!isset($_SESSION['cal_token'])) {
  69. if (isset($_GET['token'])) {
  70. // single-use トークンをセッショントークンに変換します
  71. $session_token =
  72. Zend_Gdata_AuthSub::getAuthSubSessionToken($_GET['token']);
  73. // セッショントークンをセッションに保存します
  74. $_SESSION['cal_token'] = $session_token;
  75. } else {
  76. // single-use トークンを生成するためのリンクを表示します
  77. $googleUri = Zend_Gdata_AuthSub::getAuthSubTokenUri(
  78. 'http://'. $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI'],
  79. $my_calendar, 0, 1);
  80. echo "<a href='$googleUri'>ここ</a> " .
  81. "をクリックして認証を行います。";
  82. exit();
  83. }
  84. }
  85. // Google とやり取りするための、認証済み HTTP クライアントを作成します
  86. $client = Zend_Gdata_AuthSub::getHttpClient($_SESSION['cal_token']);
  87. // 認証済み Http クライアントを使用して Gdata オブジェクトを作成します
  88. $cal = new Zend_Gdata_Calendar($client);
  89. ]]>
  90. </programlisting>
  91. </sect2>
  92. <sect2 id="zend.gdata.authsub.logout">
  93. <title>AuthSub 認証の解除</title>
  94. <para>
  95. 指定したトークンによる認証状態を終わらせるには、静的関数
  96. <classname>Zend_Gdata_AuthSub::AuthSubRevokeToken()</classname>
  97. を使用します。そうしないと、このトークンはいつまでも有効なままになります。
  98. </para>
  99. <programlisting role="php"><![CDATA[
  100. // アプリケーションのセキュリティ問題を避けるため、注意してこの値を作成します
  101. $php_self = htmlentities(substr($_SERVER['PHP_SELF'],
  102. 0,
  103. strcspn($_SERVER['PHP_SELF'], "\n\r")),
  104. ENT_QUOTES);
  105. if (isset($_GET['logout'])) {
  106. Zend_Gdata_AuthSub::AuthSubRevokeToken($_SESSION['cal_token']);
  107. unset($_SESSION['cal_token']);
  108. header('Location: ' . $php_self);
  109. exit();
  110. }
  111. ]]>
  112. </programlisting>
  113. <note>
  114. <title>セキュリティについて</title>
  115. <para>
  116. 上の例における <code>$php_self</code> の扱い方は、
  117. 一般的なセキュリティ問題の対応法に従ったものです。
  118. <classname>Zend_Gdata</classname> に固有のものではありません。
  119. http ヘッダに出力する内容は、つねにフィルタリングするようにしましょう。
  120. </para>
  121. <para>
  122. 認証トークンの解除については、ユーザが Google Data
  123. セッションを終わらせたときに行うのがお勧めです。
  124. だれかがトークンを盗んで悪用するという可能性は非常に小さいものです。
  125. とは言え、サービスの利用が終わったら認証も終了させておくことは大切です。
  126. </para>
  127. </note>
  128. </sect2>
  129. </sect1>