Zend_Session-BasicUsage.xml 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.session.basic_usage">
  5. <title>基本的な使用法</title>
  6. <para>
  7. <classname>Zend_Session_Namespace</classname>
  8. のインスタンスが、Zend Framework
  9. のセッションデータを操作するための基本的な API を提供します。
  10. 名前空間を使用するとセッションデータを個別に扱うことができますが、
  11. セッションデータ全体をひとつの名前空間で扱いたい人のためのデフォルト名前空間も用意されています。
  12. <classname>Zend_Session_Namespace</classname> は、ext/session およびスーパーグローバル変数 <code>$_SESSION</code>
  13. を使用して、セッション状態のデータを保存します。
  14. <code>$_SESSION</code> はグローバルにアクセス可能ですが、
  15. 開発者はこれに対して直接アクセスするのはやめるべきです。
  16. <classname>Zend_Session</classname> および <classname>Zend_Session_Namespace</classname> を用いることで、
  17. セッション関連の機能をより効率的かつ安全に使用できるようになります。
  18. </para>
  19. <para>
  20. <classname>Zend_Session_Namespace</classname> の各インスタンスが、
  21. スーパーグローバル配列 <code>$_SESSION</code> のエントリに対応します。
  22. 名前空間をキーとして使用します。
  23. <programlisting role="php"><![CDATA[
  24. $myNamespace = new Zend_Session_Namespace('myNamespace');
  25. // $myNamespace は $_SESSION['myNamespace'] に対応します
  26. ]]>
  27. </programlisting>
  28. Zend_Session は、<code>$_SESSION</code> を直接使用するその他のコードと組み合わせて使用することもできます。
  29. しかし、問題が起こることをさけるために、<code>$_SESSION</code>
  30. を直接使用するのは <classname>Zend_Session_Namespace</classname>
  31. のインスタンスに関連しないキーに限るようにしましょう。
  32. </para>
  33. <sect2 id="zend.session.basic_usage.basic_examples">
  34. <title>チュートリアル</title>
  35. <para>
  36. 何も名前空間を指定せずに <classname>Zend_Session_Namespace</classname> のインスタンスを作成すると、
  37. すべてのデータは透過的に "<code>Default</code>" という名前の名前空間に保存されます。
  38. <classname>Zend_Session</classname> は、セッション名前空間コンテナの内容を
  39. 直接操作するためのものではあります。そのかわりとして
  40. <classname>Zend_Session_Namespace</classname> を使用します。
  41. 以下の例は、このデフォルトの名前空間を使用して
  42. セッション内でのクライアントからのリクエストの回数を数えるものです。
  43. </para>
  44. <example id="zend.session.basic_usage.basic_examples.example.counting_page_views">
  45. <title>ページビューの数え方</title>
  46. <programlisting role="php"><![CDATA[
  47. $defaultNamespace = new Zend_Session_Namespace('Default');
  48. if (isset($defaultNamespace->numberOfPageRequests)) {
  49. // これが、ページが読み込まれるたびに加算されます
  50. $defaultNamespace->numberOfPageRequests++;
  51. } else {
  52. $defaultNamespace->numberOfPageRequests = 1; // 一回目
  53. }
  54. echo "このセッションでページがリクエストされた回数: ",
  55. $defaultNamespace->numberOfPageRequests;
  56. ]]>
  57. </programlisting>
  58. </example>
  59. <para>
  60. 複数のモジュールが別々の名前空間で <classname>Zend_Session_Namespace</classname>
  61. のインスタンスを使用するようにすると、各モジュールのデータをセッション内でカプセル化できます。
  62. <classname>Zend_Session_Namespace</classname> のコンストラクタでオプションの引数
  63. <code>$namespace</code> を指定すると、
  64. セッションデータを個別の名前空間に分割することができます。
  65. 名前空間は、セッションデータで名前の衝突による事故を防ぐための方法として、
  66. 効率的で人気のある方法です。
  67. </para>
  68. <para>
  69. 名前空間名に使用できるのは、空文字列以外の PHP の文字列です。ただし、
  70. 最初の文字にアンダースコア ("<code>_</code>") を使用することはできません。
  71. "<code>Zend</code>" で始まる名前空間を使えるのは、
  72. Zend Framework に同梱されるコアコンポーネントだけです。
  73. </para>
  74. <example id="zend.session.basic_usage.basic_examples.example.namespaces.new">
  75. <title>新しい方法: 名前空間の衝突を避ける</title>
  76. <programlisting role="php"><![CDATA[
  77. // Zend_Auth コンポーネント用
  78. $authNamespace = new Zend_Session_Namespace('Zend_Auth');
  79. $authNamespace->user = "myusername";
  80. // ウェブサービスコンポーネント用
  81. $webServiceNamespace = new Zend_Session_Namespace('Some_Web_Service');
  82. $webServiceNamespace->user = "mywebusername";
  83. ]]>
  84. </programlisting>
  85. </example>
  86. <para>
  87. 上の例は、この下のコードと同じ結果になります。
  88. ただ、上の例ではセッションデータがそれぞれの名前空間でカプセル化されています。
  89. </para>
  90. <example id="zend.session.basic_usage.basic_examples.example.namespaces.old">
  91. <title>古い方法: PHP のセッションへのアクセス</title>
  92. <programlisting role="php"><![CDATA[
  93. $_SESSION['Zend_Auth']['user'] = "myusername";
  94. $_SESSION['Some_Web_Service']['user'] = "mywebusername";
  95. ]]>
  96. </programlisting>
  97. </example>
  98. </sect2>
  99. <sect2 id="zend.session.basic_usage.iteration">
  100. <title>セッション名前空間の順次処理</title>
  101. <para>
  102. <classname>Zend_Session_Namespace</classname> は
  103. <ulink url="http://www.php.net/~helly/php/ext/spl/interfaceIteratorAggregate.html">IteratorAggregate インターフェイス</ulink>
  104. を完全に実装しており、<code>foreach</code> 文をサポートしています。
  105. </para>
  106. <example id="zend.session.basic_usage.iteration.example">
  107. <title>セッションの順次処理</title>
  108. <programlisting role="php"><![CDATA[
  109. $aNamespace =
  110. new Zend_Session_Namespace('some_namespace_with_data_present');
  111. foreach ($aNamespace as $index => $value) {
  112. echo "aNamespace->$index = '$value';\n";
  113. }
  114. ]]>
  115. </programlisting>
  116. </example>
  117. </sect2>
  118. <sect2 id="zend.session.basic_usage.accessors">
  119. <title>セッション名前空間へのアクセス方法</title>
  120. <para>
  121. <classname>Zend_Session_Namespace</classname> は <code>__get()</code>、<code>__set()</code>、
  122. <code>__isset()</code> そして <code>__unset()</code> といった
  123. <ulink url="http://www.php.net/manual/ja/language.oop5.overloading.php">マジックメソッド</ulink>
  124. を実装しています。これらは、自分のサブクラス以外から直接コールされることはありません。
  125. 次の例に示すように、通常の演算の際に自動的にコールされることになります。
  126. </para>
  127. <example id="zend.session.basic_usage.accessors.example">
  128. <title>セッションデータへのアクセス</title>
  129. <programlisting role="php"><![CDATA[
  130. $namespace = new Zend_Session_Namespace(); // デフォルトの名前空間
  131. $namespace->foo = 100;
  132. echo "\$namespace->foo = $namespace->foo\n";
  133. if (!isset($namespace->bar)) {
  134. echo "\$namespace->bar not set\n";
  135. }
  136. unset($namespace->foo);
  137. ]]>
  138. </programlisting>
  139. </example>
  140. </sect2>
  141. </sect1>