multiuser-sessions.xml 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 19778 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="learning.multiuser.sessions">
  5. <title>User Session im Zend Framework managen</title>
  6. <sect2 id="learning.multiuser.sessions.intro">
  7. <title>Einführung in Sessions</title>
  8. <para>
  9. Der Erfolg des Webs ist tief verwurzelt im Protokoll welches das Web antreibt: HTTP.
  10. HTTP über TCP ist von seiner Natur her Statuslos, was bedeutet dass auch das Web selbst
  11. Statuslos ist. Wärend dieser Aspekt einer der dominierenden Faktoren dafür ist warum das
  12. Web ein so populäres Medium geworden ist, verursacht es auch einige interessante
  13. Probleme für Entwickler welche das Web als Anwendungsplattform verwenden wollen.
  14. </para>
  15. <para>
  16. Das Akt der Interaktion mit einer Web Anwendung wird typischerweise definiert von der
  17. Summe aller Anfragen die an den Web Server gesendet werden. Da es viele Konsumenten
  18. gibt die simultan bedient werden, muss die Anwendung auswählen welche Anfragen zu
  19. welchem Benutzer gehören. Diese Anfragen sind typischerweise als "session" bekannt.
  20. </para>
  21. <para>
  22. In PHP wurde das Session Problem durch die Session Erweiterung gelöst welche eine Form
  23. der Statusverfolgung, typische Cookies und eine Form des lokalen Speichers verwendet der
  24. über die Superglobale $_SESSION bekanntgemacht wird. Im Zend Framework fügt die
  25. Komponente Zend_Session zusätzliche Vorteile zu Php's Session Erweiterung hinzu, welche
  26. es einfacher machen diese zu verwenden und auf objekt-orientierten Anwendungen beruht.
  27. </para>
  28. </sect2>
  29. <sect2 id="learning.multiuser.sessions.basic-usage">
  30. <title>Grundsätzliche Verwendung von Zend_Session</title>
  31. <para>
  32. Die Komponente Zend_Session ist sowohl ein Session Manager als auch eine API für das
  33. Speichern von Daten im Session Objekt für eine Langzeit-Verfügbarkeit. Die API von
  34. Zend_Session ist für das Managen der Optionen und des Verhaltens einer Session, wie
  35. Optionen,, Starten und Stoppen einer Session, und Zend_Session_Namespace ist das
  36. aktuelle Objekt welches zum Speichern der Daten verwendet wird.
  37. </para>
  38. <para>
  39. Wärend es generell eine gute Praxis ist eine Session im Bootstrap Prozess zu starten,
  40. ist dies generell nicht notwendig da alle Sessions bei der ersten Erstellung eines
  41. Zend_Session_Namespace Objekts automatisch gestartet werden.
  42. </para>
  43. <para>
  44. Zend_Application ist in der Lage Zend_Session als Teil des Zend_Application_Resource
  45. Systems zu konfigurieren. Um das zu verwenden, nehmen wir an dass das Projekt
  46. Zend_Application für das Bootstrappen verwendet. Man würde den folgenden Code in der
  47. Datei application.ini hinzufügen:
  48. </para>
  49. <programlisting language="php"><![CDATA[
  50. resources.session.save_path = APPLICATION_PATH "/../data/session"
  51. resources.session.use_only_cookies = true
  52. resources.session.remember_me_seconds = 864000
  53. ]]></programlisting>
  54. <para>
  55. Wie man sieht sind die übergebenen Optionen die gleichen Optionen welche man in der
  56. ext/session Erweiterung von PHP erwarten würde zu finden. Diese Optionen stellen den
  57. Pfad zu den Session Dateien ein in dem Daten des Projekts gespeichert werden. Da Ini
  58. Dateien zusätzlich Konstanten verwenden können, wird das obige die Konstante
  59. APPLICATION_PATH verwenden und relativ auf das Verzeichnis der Sessiondaten zeigen.
  60. </para>
  61. <para>
  62. Die meisten Zend Framework Komponenten welche Sessions verwenden benötigen nichts
  63. zusätzliches um Zend_Session zu verwenden. An diesem Punkt verwendet man entweder eine
  64. Komponente welche Zend_Session verwendet, oder startet das Speichern eigener Daten in
  65. einer Session mit Zend_Session_Namespace.
  66. </para>
  67. <para>
  68. Zend_Session_Namespace ist eine einfache Klasse welche auf Daten über eine einfach zu
  69. verwendende API in der von Zend_Session gemanagten superglobalen $_SESSION verweist.
  70. Der Grund warum es Zend_Session_Namespace genannt wird ist, das es die Daten in
  71. $_SESSION effektiv namespaced, und es so mehreren Komponenten und Objekten erlaubt Daten
  72. sicher zu speichern und zu empfangen. Im folgenden Code sehen wir wie ein einfacher
  73. hochzählender Counter für Sessions erstellt werden kan der bei 1000 anfängt und sich
  74. selbst nach 1999 resetiert.
  75. </para>
  76. <programlisting language="php"><![CDATA[
  77. $mysession = Zend_Session_Namespace('mysession');
  78. if (!isset($mysession->counter)) {
  79. $mysession->counter = 1000;
  80. } else {
  81. $mysession->counter++;
  82. }
  83. if ($mysession->counter > 1999) {
  84. unset($mysession->counter);
  85. }
  86. ]]></programlisting>
  87. <para>
  88. Wie man oben sieht verwendet das Session Namespace Objekt die magischen __get, __set,
  89. __isset, und __unset um die einfache und flüssige Interaktion mit der Session er
  90. erlauben. Die Information welche im obigen Beispiel gespeichert wird, wird unter
  91. $_SESSION['mysession']['counter'] gespeichert.
  92. </para>
  93. </sect2>
  94. <sect2 id="learning.multiuser.sessions.advanced-usage">
  95. <title>Gehobenere Verwendung von Zend_Session</title>
  96. <para>
  97. Wenn man zusätzlich den DbTable Speicher Handler für Zend_Session verwenden will, dann
  98. kann man den folgenden Code in der application.ini hinzufügen:
  99. </para>
  100. <programlisting language="php"><![CDATA[
  101. resources.session.saveHandler.class = "Zend_Session_SaveHandler_DbTable"
  102. resources.session.saveHandler.options.name = "session"
  103. resources.session.saveHandler.options.primary.session_id = "session_id"
  104. resources.session.saveHandler.options.primary.save_path = "save_path"
  105. resources.session.saveHandler.options.primary.name = "name"
  106. resources.session.saveHandler.options.primaryAssignment.sessionId = "sessionId"
  107. resources.session.saveHandler.options.primaryAssignment.sessionSavePath = "sessionSavePath"
  108. resources.session.saveHandler.options.primaryAssignment.sessionName = "sessionName"
  109. resources.session.saveHandler.options.modifiedColumn = "modified"
  110. resources.session.saveHandler.options.dataColumn = "session_data"
  111. resources.session.saveHandler.options.lifetimeColumn = "lifetime"
  112. ]]></programlisting>
  113. </sect2>
  114. </sect1>