Как я могу использовать сессию в таблице базы данных с php и mysql?
Вам нужно будет создать такой объект:
class SessionHandler { private static $lifetime = 0; private function __construct() //object constructor { session_set_save_handler( array($this,'open'), array($this,'close'), array($this,'read'), array($this,'write'), array($this,'destroy'), array($this,'gc') ); } public function start($session_name = null) { session_start($session_name); //Start it here } public static function open() { //Connect to mysql, if already connected, check the connection state here. return true; } public static function read($id) { //Get data from DB with id = $id; } public static function write($id, $data) { //insert data to DB, take note of serialize } public static function destroy($id) { //MySql delete sessions where ID = $id } public static function gc() { return true; } public static function close() { return true; } public function __destruct() { session_write_close(); } }
Затем перед session_start инициируйте этот класс!
include 'classes/sessionHandlerDB.php'; $session = new SessionHandler(); $session->start('userbase'); $_SESSION['name'] = 'Robert Pitt'; //This is sent to SessionHandler::write('my_id','Robert Pitt') echo $_SESSION['name']; //This calls SessionHandler::read($id)//$id is Unique Identifier for that
системыinclude 'classes/sessionHandlerDB.php'; $session = new SessionHandler(); $session->start('userbase'); $_SESSION['name'] = 'Robert Pitt'; //This is sent to SessionHandler::write('my_id','Robert Pitt') echo $_SESSION['name']; //This calls SessionHandler::read($id)//$id is Unique Identifier for that
http://php.net/manual/en/function.session-set-save-handler.php
Вы управляете этим в php.ini
соответствии с директивой session_handler
. Ознакомьтесь с http://www.tonymarston.net/php-mysql/session-handler.html, чтобы легко пройтись (использовалось ранее).
Вам нужно будет использовать session_set_save_handler
для написания пользовательских функций открытия, закрытия, чтения, записи, уничтожения и удаления мусора.
См. Мой фрагмент кода github PHP5.4-DB-Session-Handler-Class для класса управления сеансами, управляемого базой данных в PHP 5.4.