Zend_Session-SaveHandler-DbTable.xml 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.session.savehandler.dbtable">
  5. <title>Zend_Session_SaveHandler_DbTable</title>
  6. <para>
  7. Le paramétrage basique pour <classname>Zend_Session_SaveHandler_DbTable</classname>
  8. doit contenir au moins quatre colonnes, décrites dans une configuration de type
  9. <code>array</code> ou objet <classname>Zend_Config</classname> : "primary" qui est la clé
  10. primaire et reçoit par défaut l'ID de session dont le format est par défaut une chaîne de 32
  11. caractères ; "modifiedColumn" qui est le timestamp Unix de la date de dernière modification
  12. ; "lifetimeColumn" qui est la durée de vie de la session ("modified" + "lifetime" doit être
  13. supérieur à "time()") ; et "dataColumn" qui est la donnée sérialisée stockée en
  14. session.
  15. </para>
  16. <example id="zend.session.savehandler.dbtable.basic">
  17. <title>Paramétrage basique</title>
  18. <programlisting language="SQL"><![CDATA[
  19. CREATE TABLE `session` (
  20. `id` char(32),
  21. `modified` int,
  22. `lifetime` int,
  23. `data` text,
  24. PRIMARY KEY (`id`)
  25. );
  26. ]]></programlisting>
  27. <programlisting language="php"><![CDATA[
  28. // Préparation de l'adaptateur de connexion à la base de données
  29. $db = Zend_Db::factory('Pdo_Mysql', array(
  30. 'host' =>'example.com',
  31. 'username' => 'dbuser',
  32. 'password' => '******',
  33. 'dbname' => 'dbname'
  34. ));
  35. // Vous pouvez soit passer l'adaptateur par défaut à Zend_Db_Table
  36. // ou l'objet $db dans votre tableau $config
  37. Zend_Db_Table_Abstract::setDefaultAdapter($db);
  38. $config = array(
  39. 'name' => 'session',
  40. 'primary' => 'id',
  41. 'modifiedColumn' => 'modified',
  42. 'dataColumn' => 'data',
  43. 'lifetimeColumn' => 'lifetime'
  44. );
  45. // Création de votre Zend_Session_SaveHandler_DbTable
  46. // et paramétrage du gestionnaire de sauvegarde à Zend_Session
  47. Zend_Session::setSaveHandler(new Zend_Session_SaveHandler_DbTable($config));
  48. // Démarrage de la session
  49. Zend_Session::start();
  50. // Vous pouvez maintenant utiliser Zend_Session comme avant
  51. ]]></programlisting>
  52. </example>
  53. <para>
  54. Vous pouvez aussi utiliser des colonnes multiples pour votre clé primaire de
  55. <classname>Zend_Session_SaveHandler_DbTable</classname>.
  56. </para>
  57. <example id="zend.session.savehandler.dbtable.multi-column-key">
  58. <title>Utilisation d'une clé primaire multi-colonnes</title>
  59. <programlisting language="SQL"><![CDATA[
  60. CREATE TABLE `session` (
  61. `session_id` char(32) NOT NULL,
  62. `save_path` varchar(32) NOT NULL,
  63. `name` varchar(32) NOT NULL DEFAULT '',
  64. `modified` int,
  65. `lifetime` int,
  66. `session_data` text,
  67. PRIMARY KEY (`Session_ID`, `save_path`, `name`)
  68. );
  69. ]]></programlisting>
  70. <programlisting language="php"><![CDATA[
  71. // Préparation de l'adaptateur de connexion à la base de données comme ci-dessus
  72. // NOTE : cette configuration est fournie à Zend_Db_Table donc tout élément spécifique à la table peut y être ajouté
  73. $config = array(
  74. 'name' => 'session',
  75. // Nom de la table comme pour Zend_Db_Table
  76. 'primary' => array(
  77. 'session_id',
  78. // l'ID de session fourni par PHP
  79. 'save_path',
  80. // session.save_path
  81. 'name',
  82. // session name
  83. ),
  84. 'primaryAssignment' => array(
  85. // vous devez avertir le gestionnaire de sauvegarde quelles colonnes
  86. // vous utilisez en tant que clé primaire. L'ORDRE EST IMPORTANT.
  87. 'sessionId',
  88. // - la première colonne de la clé primaire est l'ID de session
  89. 'sessionSavePath',
  90. // - la seconde colonne de la clé primaire est le "save path"
  91. 'sessionName',
  92. // - la troisième colonne de la clé primaire est le "session name"
  93. ),
  94. 'modifiedColumn' => 'modified',
  95. // date de la dernière modification
  96. 'dataColumn' => 'session_data',
  97. // donnée sérialisée
  98. 'lifetimeColumn' => 'lifetime',
  99. // durée de vie de l'enregistrement
  100. );
  101. // Informez Zend_Session d'utiliser votre gestionnaire de sauvegarde
  102. Zend_Session::setSaveHandler(
  103. new Zend_Session_SaveHandler_DbTable($config)
  104. );
  105. // Démarrage de la session
  106. Zend_Session::start();
  107. // Utilisez Zend_Session normalement
  108. ]]></programlisting>
  109. </example>
  110. </sect1>