Zend_Session-BasicUsage.xml 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <sect1 id="zend.session.basic_usage">
  2. <title>基本用法</title>
  3. <para>
  4. 在Zend Framework中,<code>Zend_Session_Namespace</code>实例提供了操作会话数据主要的API。命名空间常用于隔离所有的会话数据,尽管也为所有会话数据只需要一个命名空间的情况提供了一个默认的命名空间。Zend_Session利用了PHP内置的会话模块(ext/session),以及它特有的<code>$_SESSION</code>全局数组做为会话状态数据的存储机制。虽然<code>$_SESSION</code>在PHP的全局命名空间内仍然可以访问,但是开发者不应该直接访问它,这样<code>Zend_Session</code> 和 <code>Zend_Session_Namespace</code>可以提供一组最可靠、安全的处理会话相关的功能。
  5. </para>
  6. <para>
  7. 每个<code>Zend_Session_Namespace</code>的实例对应于<code>$_SESSION</code>全局数组的一个条目,在那里命名空间被用作键。
  8. <programlisting role="php"><![CDATA[<?php
  9. require_once 'Zend/Session/Namespace.php';
  10. $myNamespace = new Zend_Session_Namespace('myNamespace');
  11. // $myNamespace corresponds to $_SESSION['myNamespace']]]>
  12. </programlisting>
  13. 用Zend_Session直接和其它使用 <code>$_SESSION</code>的代码协同工作是可能的。然而,为避免问题,强烈建议这样的代码只使用<code>$_SESSION</code>中不和<code>Zend_Session_Namespace</code>的实例想对应的部分。
  14. </para>
  15. <sect2 id="zend.session.basic_usage.basic_examples">
  16. <title>实例教程</title>
  17. <para>
  18. 在初始化Zend_Session时,如果没有指定命名空间,所有的数据将被透明地储存在<code>'Default'</code>命名空间下。<code>Zend_Session</code>不打算直接处理会话命名空间容器的内容,取而代之,我们可以使用<code>Zend_Session_Namespace</code>。下面的例子演示了缺省命名空间的使用,和怎样计算用户访问页面的次数:
  19. </para>
  20. <example id="zend.session.basic_usage.basic_examples.example.counting_page_views">
  21. <title>页面浏览计数</title>
  22. <programlisting role="php"><![CDATA[<?php
  23. require_once 'Zend/Session/Namespace.php';
  24. $defaultNamespace = new Zend_Session_Namespace('Default');
  25. if (isset($defaultNamespace->numberOfPageRequests)) {
  26. $defaultNamespace->numberOfPageRequests++; // 每次页面加载,这个将递增
  27. } else {
  28. $defaultNamespace->numberOfPageRequests = 1; // 第一次
  29. }
  30. echo "Page requests this session: ", $defaultNamespace->numberOfPageRequests;]]>
  31. </programlisting>
  32. </example>
  33. <para>
  34. 当多个模块使用<code>Zend_Session_Namespace</code>的实例拥有不同的命名空间,每个模块为它自己的会话数据获得数据封装。可以传递给<code>Zend_Session_Namespace</code>构造函数一个可选的<code>$namespace</code>参数,它允许开发者分割会话数据到分离的命名空间。命名空间机制提供了一个有效的、流行的方法来确保处于命名空间之下的会话数据不遭到意外地改变。
  35. </para>
  36. <para>
  37. 命名空间的名称被限定为字符序列,它表示为不以下划线("<code>_</code>")开头的非空PHP字符串。只有Zend Framework的核心模块可使用以"<code>Zend</code>"开头的命名空间的名称。
  38. </para>
  39. <example id="zend.session.basic_usage.basic_examples.example.namespaces.new">
  40. <title>新方法: 使用命名空间避免冲突</title>
  41. <programlisting role="php"><![CDATA[<?php
  42. require_once 'Zend/Session/Namespace.php';
  43. // in the Zend_Auth component
  44. $authNamespace = new Zend_Session_Namespace('Zend_Auth');
  45. $authNamespace->user = "myusername";
  46. // in a web services component
  47. $webServiceNamespace = new Zend_Session_Namespace('Some_Web_Service');
  48. $webServiceNamespace->user = "mywebusername";]]>
  49. </programlisting>
  50. </example>
  51. <para>
  52. 上述例子中的代码与下面的代码有相同的效果,不过,上述例子中的会话对象把会话数据封装进了各自的命名空间。
  53. </para>
  54. <example id="zend.session.basic_usage.basic_examples.example.namespaces.old">
  55. <title>老方法: PHP会话访问</title>
  56. <programlisting role="php"><![CDATA[<?php
  57. $_SESSION['Zend_Auth']['user'] = "myusername";
  58. $_SESSION['Some_Web_Service']['user'] = "mywebusername";]]>
  59. </programlisting>
  60. </example>
  61. </sect2>
  62. <sect2 id="zend.session.basic_usage.iteration">
  63. <title>迭代会话命名空间</title>
  64. <para>
  65. <code>Zend_Session_Namespace</code>提供了<ulink url="http://www.php.net/~helly/php/ext/spl/interfaceIteratorAggregate.html">IteratorAggregate接口</ulink>所有的能力,包括对<code>foreach</code>语句的支持:
  66. </para>
  67. <example id="zend.session.basic_usage.iteration.example">
  68. <title>会话迭代</title>
  69. <programlisting role="php"><![CDATA[<?php
  70. require_once 'Zend/Session/Namespace.php';
  71. $aNamespace = new Zend_Session_Namespace('some_namespace_with_data_present');
  72. foreach ($aNamespace as $index => $value) {
  73. echo "aNamespace->$index = '$value';\n";
  74. }]]>
  75. </programlisting>
  76. </example>
  77. </sect2>
  78. <sect2 id="zend.session.basic_usage.accessors">
  79. <title>会话命名空间的访问器</title>
  80. <para>
  81. <code>Zend_Session_Namespace</code>实现<code>__get()</code>, <code>__set()</code>, <code>__isset()</code>, and <code>__unset()</code>这些 <ulink url="http://www.php.net/manual/en/language.oop5.overloading.php">魔术方法</ulink>,除了在一个子类里,这些魔术方法不能被直接调用。相反,正常的操作符自动调用这些方法,如下例所示:
  82. </para>
  83. <example id="zend.session.basic_usage.accessors.example">
  84. <title>访问会话数据</title>
  85. <programlisting role="php"><![CDATA[<?php
  86. require_once 'Zend/Session/Namespace.php';
  87. $namespace = new Zend_Session_Namespace(); // 缺省的命名空间
  88. $namespace->foo = 100;
  89. echo "\$namespace->foo = $namespace->foo\n";
  90. if (!isset($namespace->bar)) {
  91. echo "\$namespace->bar not set\n";
  92. }
  93. unset($namespace->foo);]]>
  94. </programlisting>
  95. </example>
  96. </sect2>
  97. </sect1>