Zend_Http_Cookie-Handling.xml 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24856 -->
  4. <sect1 id="zend.http.cookies">
  5. <title>Zend_Http_Cookie および Zend_Http_CookieJar</title>
  6. <sect2 id="zend.http.cookies.introduction">
  7. <title>導入</title>
  8. <para>
  9. <classname>Zend_Http_Cookie</classname> は、お察しのとおり、<acronym>HTTP</acronym> クッキーを表すクラスです。
  10. <acronym>HTTP</acronym> レスポンス文字列をパースしたりクッキーを収集したり、
  11. そしてプロパティに簡単にアクセスしたりするためのメソッドがあります。
  12. また、クッキーが所定の条件にマッチしているかどうかを調べることもできます。
  13. たとえばリクエスト <acronym>URL</acronym>、有効期限、セキュア接続か否かなどを調べます。
  14. </para>
  15. <para>
  16. <classname>Zend_Http_CookieJar</classname> は主に <classname>Zend_Http_Client</classname> で用いられ、ひとつあるいは複数の
  17. <classname>Zend_Http_Cookie</classname> オブジェクトを保持します。
  18. <classname>Zend_Http_CookieJar</classname> オブジェクトを <classname>Zend_Http_Client</classname>
  19. オブジェクトにアタッチすると、
  20. クライアントから <acronym>HTTP</acronym> リクエストで送られるクッキーや
  21. クライアントが <acronym>HTTP</acronym> レスポンスで受け取るクッキーがすべて
  22. CookieJar オブジェクトに保存されます。そして、
  23. クライアントが別のリクエストを送信する際には、まず CookieJar
  24. オブジェクトを調べてリクエストにマッチするクッキーがあるかどうかを確認します。
  25. あった場合は、それが自動的にリクエストヘッダに追加されます。
  26. これは、連続した <acronym>HTTP</acronym> リクエストでユーザのセッションを保持し続けたい場合に便利です。
  27. セッション ID が保存されたクッキーを、必要に応じて自動的に送信することができます。
  28. さらに、必要に応じて <classname>Zend_Http_CookieJar</classname> オブジェクトをシリアライズし、
  29. $_SESSION に格納することもできます。
  30. </para>
  31. </sect2>
  32. <sect2 id="zend.http.cookies.cookie.instantiating">
  33. <title>Zend_Http_Cookie のインスタンスの作成</title>
  34. <para>
  35. クッキーオブジェクトのインスタンスを作成する方法は二通りあります。
  36. <itemizedlist>
  37. <listitem>
  38. <para>
  39. コンストラクタで以下のような構文を使用します。
  40. <command>new <classname>Zend_Http_Cookie</classname>(string $name, string $value, string $domain, [int $expires, [string $path, [boolean $secure]]]);</command>
  41. </para>
  42. <itemizedlist>
  43. <listitem>
  44. <para>
  45. <code>$name</code>: クッキーの名前 (例 'PHPSESSID') (必須)
  46. </para>
  47. </listitem>
  48. <listitem>
  49. <para>
  50. <code>$value</code>: クッキーの値 (必須)
  51. </para>
  52. </listitem>
  53. <listitem>
  54. <para>
  55. <code>$domain</code>: クッキーのドメイン (例 '.example.com') (必須)
  56. </para>
  57. </listitem>
  58. <listitem>
  59. <para>
  60. <code>$expires</code>: クッキーの有効期限を表す UNIX タイムスタンプ (任意。既定値は <constant>NULL</constant>)。
  61. 設定しなかった場合は、有効期限なしの 'セッションクッキー' として扱われます。
  62. </para>
  63. </listitem>
  64. <listitem>
  65. <para>
  66. <code>$path</code>: クッキーのパス。たとえば '/foo/bar/' (任意。既定値は '/')
  67. </para>
  68. </listitem>
  69. <listitem>
  70. <para>
  71. <code>$secure</code>: クッキーの送信をセキュア接続 (<acronym>HTTPS</acronym>)
  72. 時に限るかどうか (任意。既定値は <constant>FALSE</constant>)
  73. </para>
  74. </listitem>
  75. </itemizedlist>
  76. </listitem>
  77. <listitem>
  78. <para>
  79. 静的メソッド fromString($cookieStr, [$refUri, [$encodeValue]]) をコールし、<acronym>HTTP</acronym> レスポンスヘッダ 'Set-Cookie'
  80. あるいは <acronym>HTTP</acronym> リクエストヘッダ 'Cookie' に対応するクッキー文字列を指定します。
  81. この場合、クッキーの値は事前にエンコードしておく必要があります。
  82. クッキー文字列に 'domain' 部分が含まれない場合は、
  83. クッキーのドメインとパスを設定するための参照 <acronym>URI</acronym> を指定する必要があります。
  84. </para>
  85. <para>
  86. <methodname>fromString()</methodname> メソッドでは下記のパラメータを受け付けます。
  87. </para>
  88. <itemizedlist>
  89. <listitem>
  90. <para>
  91. <varname>$cookieStr</varname>:
  92. 'Set-Cookie' <acronym>HTTP</acronym> レスポンス・ヘッダや、必須の
  93. 'Cookie' <acronym>HTTP</acronym> リクエスト・ヘッダで表現されるようなクッキー文字列。
  94. </para>
  95. </listitem>
  96. <listitem>
  97. <para>
  98. <varname>$refUri</varname>:
  99. クッキーのドメインとパスがセットされる参照 <acronym>URI</acronym>。
  100. (任意。既定値では $cookieStr から値をパースします)
  101. </para>
  102. </listitem>
  103. <listitem>
  104. <para>
  105. <varname>$encodeValue</varname>:
  106. 値が urldecode を介して渡されるべきかどうか。
  107. クッキー文字列に変換される際に、クッキーのふるまいにも影響します。
  108. (任意。既定値は true)
  109. </para>
  110. </listitem>
  111. </itemizedlist>
  112. </listitem>
  113. </itemizedlist>
  114. <example id="zend.http.cookies.cookie.instantiating.example-1">
  115. <title>Zend_Http_Cookie のインスタンスの作成</title>
  116. <programlisting language="php"><![CDATA[
  117. // まずはコンストラクタを使用します。このクッキーの有効期限は二時間です。
  118. $cookie = new Zend_Http_Cookie('foo',
  119. 'bar',
  120. '.example.com',
  121. time() + 7200,
  122. '/path');
  123. // HTTP レスポンスヘッダ Set-Cookie を設定して使用することもできます。
  124. // このクッキーは先ほどのものとほとんど同じですが、有効期限はありません。
  125. // また、セキュア接続時にのみ送信されます。
  126. $cookie = Zend_Http_Cookie::fromString('foo=bar; domain=.example.com; ' .
  127. 'path=/path; secure');
  128. // クッキーのドメインが設定されていない場合は、手動で設定する必要があります。
  129. $cookie = Zend_Http_Cookie::fromString('foo=bar; secure;',
  130. 'http://www.example.com/path');
  131. ]]></programlisting>
  132. </example>
  133. <note>
  134. <para>
  135. クッキーオブジェクトを作成するのに <classname>Zend_Http_Cookie</classname>::fromString()
  136. メソッドを使用した場合は、クッキーの値は <acronym>URL</acronym> エンコードされていなければなりません。
  137. これはクッキー文字列と同様です。しかし、コンストラクタを使用する場合は、
  138. エンコードされたものではなく、デコードされた実際の値を使用します。
  139. </para>
  140. </note>
  141. </para>
  142. <para>
  143. クッキーオブジェクトを文字列に変換するには、マジックメソッド __toString()
  144. を使用します。このメソッドは、<acronym>HTTP</acronym> リクエストヘッダ "Cookie" 用の文字列を作成します。
  145. クッキーの名前と値が表示され、最後はセミコロン (';') となります。
  146. この値は <acronym>URL</acronym> エンコードされ、そのまま Cookie ヘッダとして使用できるようになります。
  147. <example id="zend.http.cookies.cookie.instantiating.example-2">
  148. <title>Zend_Http_Cookie オブジェクトの文字列化</title>
  149. <programlisting language="php"><![CDATA[
  150. // 新しいクッキーを作成します。
  151. $cookie = new Zend_Http_Cookie('foo',
  152. 'two words',
  153. '.example.com',
  154. time() + 7200,
  155. '/path');
  156. // これは 'foo=two+words;' を表示します。
  157. echo $cookie->__toString();
  158. // 上と同じことです。
  159. echo (string) $cookie;
  160. // PHP 5.2 以降では、これでもかまいません。
  161. echo $cookie;
  162. ]]></programlisting>
  163. </example>
  164. </para>
  165. </sect2>
  166. <sect2 id="zend.http.cookies.cookie.accessors">
  167. <title>Zend_Http_Cookie のゲッターメソッド</title>
  168. <para>
  169. <classname>Zend_Http_Cookie</classname> のインスタンスを作成すると、
  170. <acronym>HTTP</acronym> クッキーのさまざまなプロパティを取得するためのメソッドが使用できるようになります。
  171. <itemizedlist>
  172. <listitem>
  173. <para>
  174. <methodname>getName()</methodname>: クッキーの名前を取得します。
  175. </para>
  176. </listitem>
  177. <listitem>
  178. <para>
  179. <methodname>getValue()</methodname>: デコードされたクッキーの値を取得します。
  180. </para>
  181. </listitem>
  182. <listitem>
  183. <para>
  184. <methodname>getDomain()</methodname>: クッキーのドメインを取得します。
  185. </para>
  186. </listitem>
  187. <listitem>
  188. <para>
  189. <methodname>getPath()</methodname>: クッキーのパスを取得します。既定値は '/' です。
  190. </para>
  191. </listitem>
  192. <listitem>
  193. <para>
  194. <methodname>getExpiryTime()</methodname>: クッキーの有効期限を UNIX タイムスタンプで取得します。
  195. 設定されていない場合は <constant>NULL</constant> を返します。
  196. </para>
  197. </listitem>
  198. </itemizedlist>
  199. </para>
  200. <para>
  201. さらに、チェック用のメソッドも提供されています。
  202. <itemizedlist>
  203. <listitem>
  204. <para>
  205. <methodname>isSecure()</methodname>: クッキーの送信がセキュア接続に限定されているかどうかを調べます。
  206. 要するに、もし <constant>TRUE</constant> ならそのクッキーは <acronym>HTTPS</acronym> でしか送信されないということです。
  207. </para>
  208. </listitem>
  209. <listitem>
  210. <para>
  211. <methodname>isExpired(int $time = null)</methodname>: クッキーが有効期限切れになっているかどうかを調べます。
  212. 有効期限が設定されていない場合は、常に <constant>TRUE</constant> を返します。$time を指定すると、
  213. その時刻の時点で有効期限切れになるのかどうかを調べます。
  214. </para>
  215. </listitem>
  216. <listitem>
  217. <para>
  218. <methodname>isSessionCookie()</methodname>: クッキーが "セッションクッキー"、
  219. すなわち有効期限を持たないクッキー (セッション終了時に無効になるクッキー)
  220. であるかどうかを調べます。
  221. </para>
  222. </listitem>
  223. </itemizedlist>
  224. </para>
  225. <para>
  226. <example id="zend.http.cookies.cookie.accessors.example-1">
  227. <title>Zend_Http_Cookie のゲッターメソッドの使用法</title>
  228. <programlisting language="php"><![CDATA[
  229. // まずクッキーを作成します
  230. $cookie =
  231. Zend_Http_Cookie::fromString('foo=two+words; ' +
  232. 'domain=.example.com; ' +
  233. 'path=/somedir; ' +
  234. 'secure; ' +
  235. 'expires=Wednesday, 28-Feb-05 20:41:22 UTC');
  236. echo $cookie->getName(); // これは 'foo' を表示します
  237. echo $cookie->getValue(); // これは 'two words' を表示します
  238. echo $cookie->getDomain(); // これは '.example.com' を表示します
  239. echo $cookie->getPath(); // これは '/' を表示します
  240. echo date('Y-m-d', $cookie->getExpiryTime());
  241. // これは '2005-02-28' を表示します
  242. echo ($cookie->isExpired() ? 'Yes' : 'No');
  243. // これは 'Yes' を表示します
  244. echo ($cookie->isExpired(strtotime('2005-01-01') ? 'Yes' : 'No');
  245. // これは 'No' を表示します
  246. echo ($cookie->isSessionCookie() ? 'Yes' : 'No');
  247. // これは 'No' を表示します
  248. ]]></programlisting>
  249. </example>
  250. </para>
  251. </sect2>
  252. <sect2 id="zend.http.cookies.cookie.matching">
  253. <title>Zend_Http_Cookie が条件に一致するものかどうかを調べる</title>
  254. <para>
  255. 調べるために <classname>Zend_Http_Cookie</classname> に含まれているのは match() メソッドだけです。
  256. このメソッドを使用して、送ろうとしている <acronym>HTTP</acronym> リクエストに当てはまるクッキーであるかどうかを調べます。
  257. その結果によって、クッキーをこのリクエストで送信するかどうかが決まります。
  258. メソッドの構文やパラメータの内容は以下のとおりです。
  259. <command>Zend_Http_Cookie->match(mixed $uri, [boolean $matchSessionCookies, [int $now]]);</command>
  260. <itemizedlist>
  261. <listitem>
  262. <para>
  263. <varname>$uri</varname>: <classname>Zend_Uri_Http</classname> オブジェクトで、
  264. ドメインやパスのチェックに使用します。オプションとして、
  265. 正しい形式の <acronym>URL</acronym> を文字列で渡すこともできます。
  266. 指定した <acronym>URL</acronym> のスキーム (<acronym>HTTP</acronym> あるいは <acronym>HTTPS</acronym>)、
  267. ドメインおよびパスがすべて一致した場合にのみ、クッキーがマッチします。
  268. </para>
  269. </listitem>
  270. <listitem>
  271. <para>
  272. <varname>$matchSessionCookies</varname>:
  273. セッションクッキーをマッチの対象にするかどうか。
  274. 既定値は <constant>TRUE</constant> です。<constant>FALSE</constant> に設定すると、
  275. 有効期限の設定されていないクッキーはマッチしません。
  276. </para>
  277. </listitem>
  278. <listitem>
  279. <para>
  280. <varname>$now</varname>: クッキーの有効期限をチェックする基準となる時刻
  281. (UNIX タイムスタンプ形式)。指定しない場合の既定値は、現在時刻です。
  282. </para>
  283. </listitem>
  284. </itemizedlist>
  285. <example id="zend.http.cookies.cookie.matching.example-1">
  286. <title>クッキーがマッチするかどうかの確認</title>
  287. <programlisting language="php"><![CDATA[
  288. // まずクッキーオブジェクトを作成します。これはセキュアなセッションクッキーです。
  289. $cookie = Zend_Http_Cookie::fromString('foo=two+words; ' +
  290. 'domain=.example.com; ' +
  291. 'path=/somedir; ' +
  292. 'secure;');
  293. $cookie->match('https://www.example.com/somedir/foo.php');
  294. // これは true を返します。
  295. $cookie->match('http://www.example.com/somedir/foo.php');
  296. // これは false を返します。接続がセキュアでないからです。
  297. $cookie->match('https://otherexample.com/somedir/foo.php');
  298. // これは false を返します。ドメインが違っているからです。
  299. $cookie->match('https://example.com/foo.php');
  300. // これは false を返します。パスが違っているからです。
  301. $cookie->match('https://www.example.com/somedir/foo.php', false);
  302. // これは false を返します。セッションクッキーはマッチさせないようにしているからです。
  303. $cookie->match('https://sub.domain.example.com/somedir/otherdir/foo.php');
  304. // これは true を返します。
  305. // 別のクッキーオブジェクトを作成します。今度はセキュアではなく、
  306. // 二時間で有効期限切れとなります。
  307. $cookie = Zend_Http_Cookie::fromString('foo=two+words; ' +
  308. 'domain=www.example.com; ' +
  309. 'expires='
  310. . date(DATE_COOKIE, time() + 7200));
  311. $cookie->match('http://www.example.com/');
  312. // これは true を返します。
  313. $cookie->match('https://www.example.com/');
  314. // これは true を返します。セキュアでないクッキーは、
  315. // セキュアな通信でも送信されます!
  316. $cookie->match('http://subdomain.example.com/');
  317. // これは false を返します。ドメインが違っているからです。
  318. $cookie->match('http://www.example.com/', true, time() + (3 * 3600));
  319. // これは false を返します。今から三時間後の時刻を指定したからです。
  320. ]]></programlisting>
  321. </example>
  322. </para>
  323. </sect2>
  324. <sect2 id="zend.http.cookies.cookiejar">
  325. <title>Zend_Http_CookieJar のインスタンスの作成</title>
  326. <para>
  327. <classname>Zend_Http_CookieJar</classname> のインスタンスを直接作成する必要は、まずありません。
  328. 新しいクッキージャーを <classname>Zend_Http_Client</classname> オブジェクトにアタッチするには、単に
  329. Zend_Http_Client->setCookieJar() メソッドをコールすればいいのです。これで、
  330. 新しい空のクッキージャーがクライアントに追加されます。このクッキージャーを取得するには
  331. Zend_Http_Client->getCookieJar() を使用します。
  332. </para>
  333. <para>
  334. それでもやっぱり自分で CookieJar のインスタンスを作成したいというのなら、
  335. "new Zend_Http_CookieJar()" と直接コールしてください。
  336. コンストラクタには引数を何も指定しません。インスタンスを作成するもうひとつの方法としては、
  337. 静的メソッド Zend_Http_CookieJar::fromResponse() を使用するものがあります。
  338. このメソッドは二つのパラメータを受け取ります。まず最初が <classname>Zend_Http_Response</classname>
  339. オブジェクト、そして二つ目は参照先 <acronym>URI</acronym> で、これは文字列あるいは
  340. <classname>Zend_Uri_Http</classname> オブジェクトのいずれかです。
  341. このメソッドは新しい <classname>Zend_Http_CookieJar</classname> オブジェクトを返します。
  342. このオブジェクトには、指定した <acronym>HTTP</acronym> レスポンスによって設定されたクッキーが既に含まれています。
  343. クッキーのドメインとパスが Set-Cookie ヘッダで指定されていない場合は、
  344. 参照先 <acronym>URI</acronym> を使用して設定します。
  345. </para>
  346. </sect2>
  347. <sect2 id="zend.http.cookies.cookiejar.adding_cookies">
  348. <title>Zend_Http_CookieJar オブジェクトへのクッキーの追加</title>
  349. <para>
  350. 通常は、CookieJar オブジェクトを追加した <classname>Zend_Http_Client</classname> オブジェクトが自動的に処理を行い、
  351. <acronym>HTTP</acronym> レスポンスで設定されたクッキーをジャーに追加してくれます。
  352. 自分でクッキーをジャーに追加するには、二通りの方法があります。
  353. <itemizedlist>
  354. <listitem>
  355. <para>
  356. <classname>Zend_Http_CookieJar->addCookie($cookie[, $ref_uri])</classname>:
  357. 単一のクッキーをジャーに追加します。$cookie には <classname>Zend_Http_Cookie</classname>
  358. オブジェクトあるいは文字列を指定します。文字列は自動的に
  359. Cookie オブジェクトに変換されます。文字列を指定する場合は、同時に
  360. $ref_uri も指定しなければなりません。これは参照先 <acronym>URI</acronym> で、文字列あるいは
  361. <classname>Zend_Uri_Http</classname> オブジェクトを渡します。これをもとにして、
  362. クッキーのデフォルトのドメインとパスを決定します。
  363. </para>
  364. </listitem>
  365. <listitem>
  366. <para>
  367. <classname>Zend_Http_CookieJar->addCookiesFromResponse($response, $ref_uri)</classname>:
  368. <acronym>HTTP</acronym> レスポンス内のすべてのクッキーをジャーに追加します。
  369. $response は Set-Cookie ヘッダつきの <classname>Zend_Http_Response</classname> オブジェクトです。
  370. $ref_uri は参照先 <acronym>URI</acronym> で、文字列あるいは <classname>Zend_Uri_Http</classname> オブジェクトとなります。
  371. これをもとにして、クッキーのデフォルトのドメインとパスを決定します。
  372. </para>
  373. </listitem>
  374. </itemizedlist>
  375. </para>
  376. </sect2>
  377. <sect2 id="zend.http.cookies.cookiejar.getting_cookies">
  378. <title>Zend_Http_CookieJar オブジェクトからのクッキーの取得</title>
  379. <para>
  380. クッキーを追加する場合と同様、クッキーをジャーから取得する作業についても
  381. 通常は手動で行う必要はありません。<classname>Zend_Http_Client</classname>
  382. オブジェクトは、その <acronym>HTTP</acronym> リクエストで必要なクッキーを自動的に取得します。
  383. とは言え、ジャーから手動でクッキーを取得するための方法も提供されています。
  384. <methodname>getCookie()</methodname>、
  385. <methodname>getAllCookies()</methodname> および <methodname>getMatchingCookies()</methodname>
  386. の三通りの方法です。
  387. さらに、CookieJar を順次処理していくことで、そこからすべての
  388. <classname>Zend_Http_Cookie</classname> オブジェクトを取得することができます。
  389. </para>
  390. <para>
  391. 注意すべき点は、これらのメソッドが特別なパラメータを受け取るようになっているということです。
  392. このパラメータで、メソッドの返り値の型を指定します。
  393. 指定できる値は次の三種類です。
  394. <itemizedlist>
  395. <listitem>
  396. <para>
  397. <constant>Zend_Http_CookieJar::COOKIE_OBJECT</constant>:
  398. <classname>Zend_Http_Cookie</classname> オブジェクトを返します。
  399. 返されるクッキーが複数の場合は、オブジェクトの配列を返します。
  400. </para>
  401. </listitem>
  402. <listitem>
  403. <para>
  404. <constant>Zend_Http_CookieJar::COOKIE_STRING_ARRAY</constant>:
  405. "foo=bar" 形式の文字列を返します。これは、<acronym>HTTP</acronym> リクエストの "Cookie"
  406. ヘッダで使用できる形式です。
  407. 返されるクッキーが複数の場合は、文字列の配列を返します。
  408. </para>
  409. </listitem>
  410. <listitem>
  411. <para>
  412. <constant>Zend_Http_CookieJar::COOKIE_STRING_CONCAT</constant>:
  413. COOKIE_STRING_ARRAY と似ていますが、返されるクッキーが複数の場合には
  414. それらをひとつの長い文字列に連結して返します。
  415. 区切り文字はセミコロン (;) となります。
  416. これは、マッチするすべてのクッキーを単一の <acronym>HTTP</acronym> リクエストヘッダ
  417. "Cookie" で送信したい場合に非常に便利です。
  418. </para>
  419. </listitem>
  420. <!-- TODO : to be translated -->
  421. <listitem>
  422. <para>
  423. <constant>Zend_Http_CookieJar::COOKIE_STRING_CONCAT_STRICT</constant>: Similar to
  424. COOKIE_STRING_CONCAT, but follows a strict implementation of RFC6265. In this mode,
  425. a single space character always follows the semicolon separator between cookies, and
  426. the semicolon separator is stripped from the end of the cookie string.
  427. </para>
  428. </listitem>
  429. </itemizedlist>
  430. </para>
  431. <para>
  432. クッキー取得のためのさまざまなメソッドのについて説明します。
  433. <itemizedlist>
  434. <listitem>
  435. <para>
  436. <classname>Zend_Http_CookieJar->getCookie($uri, $cookie_name[, $ret_as])</classname>:
  437. その <acronym>URI</acronym> (ドメインおよびパス) と名前にもとづいて、
  438. ジャーから単一のクッキーを取得します。
  439. $uri は文字列か <classname>Zend_Uri_Http</classname> オブジェクトで、<acronym>URI</acronym> を表します。
  440. $cookie_name はクッキー名を表す文字列です。
  441. $ret_as は先ほど説明したように返り値の型を指定します。
  442. $ret_type はオプションで、既定値は COOKIE_OBJECT です。
  443. </para>
  444. </listitem>
  445. <listitem>
  446. <para>
  447. <classname>Zend_Http_CookieJar->getAllCookies($ret_as)</classname>:
  448. ジャーからすべてのクッキーを取得します。
  449. $ret_as は先ほど説明したように返り値の型を指定します。
  450. 指定しなかった場合の $ret_type の既定値は、COOKIE_OBJECT となります。
  451. </para>
  452. </listitem>
  453. <listitem>
  454. <para>
  455. <classname>Zend_Http_CookieJar->getMatchingCookies($uri[, $matchSessionCookies[, $ret_as[, $now]]])</classname>:
  456. 指定した条件を満たす全てのクッキーをジャーから取得します。
  457. 条件として指定するのは、<acronym>URI</acronym> および有効期限です。
  458. <itemizedlist>
  459. <listitem>
  460. <para>
  461. <code>$uri</code> は <classname>Zend_Uri_Http</classname> オブジェクトあるいは文字列です。
  462. 接続形式 (セキュアかそうでないか)、ドメインおよびパスの条件を指定します。
  463. </para>
  464. </listitem>
  465. <listitem>
  466. <para>
  467. <code>$matchSessionCookies</code> は boolean 値で、
  468. セッションクッキーを含めるかどうかを指定します。
  469. セッションクッキーとは、有効期限が指定されていないクッキーのことです。
  470. 既定値は <constant>TRUE</constant> です。
  471. </para>
  472. </listitem>
  473. <listitem>
  474. <para>
  475. <code>$ret_as</code>
  476. は、先ほど説明したように返り値の型を指定します。
  477. 指定しなかった場合の既定値は COOKIE_OBJECT です。
  478. </para>
  479. </listitem>
  480. <listitem>
  481. <para>
  482. <code>$now</code> は整数値で表した UNIX タイムスタンプで、
  483. これを "現在時刻" として扱います。
  484. 有効期限がこの時刻より前に設定されているクッキーはマッチしません。
  485. 指定しなかった場合の既定値は、現在時刻です。
  486. </para>
  487. </listitem>
  488. </itemizedlist>
  489. クッキーのマッチ方法についての詳細は
  490. <link linkend="zend.http.cookies.cookie.matching">このセクション</link>
  491. を参照してください。
  492. </para>
  493. </listitem>
  494. </itemizedlist>
  495. </para>
  496. </sect2>
  497. </sect1>
  498. <!--
  499. vim:se ts=4 sw=4 et:
  500. -->