PHP實現(xiàn)session信息存儲到數(shù)據(jù)庫
來源:易賢網(wǎng) 閱讀:1008 次 日期:2015-04-15 15:10:06
溫馨提示:易賢網(wǎng)小編為您整理了“PHP實現(xiàn)session信息存儲到數(shù)據(jù)庫”,方便廣大網(wǎng)友查閱!

PHP實現(xiàn)session信息存儲到數(shù)據(jù)庫,具體代碼如下:

/**

* session信息存儲到數(shù)據(jù)庫的類

* 表結(jié)構(gòu):

* CREATE TABLE IF NOT EXISTS `sessioninfo` (

* `sid` varchar(255) NOT NULL,

* `value` text NOT NULL,

* `expiration` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,

* PRIMARY KEY (`sid`)

* ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

*/

class MySessionHandler implements SessionHandlerInterface {

/**

* @access private

* @var object 數(shù)據(jù)庫連接

*/

private $_dbLink;

/**

* @access private

* @var string 保存session的表名

*/

Private $_sessionTable;

/**

* @access private

* @var string session名

*/

private $_sessionName;

/**

* @const 過期時間

*/

const SESSION_EXPIRE = 10;

public function __construct($dbLink, $sessionTable) {

if(!is_object($dbLink)) {

return false;

}

$this->_dbLink = $dbLink;

$this->_sessionTable = $sessionTable;

}

/**

* 打開

* @access public

* @param string $session_save_path 保存session的路徑

* @param string $session_name session名

* @return integer

*/

public function open($session_save_path, $session_name) {

$this->_sessionName = $session_name;

return 0;

}

/**

* 關(guān)閉

* @access public

* @return integer

*/

public function close() {

return 0;

}

/**

* 關(guān)閉session

* @access public

* @param string $session_id session ID

* @return string

*/

public function read($session_id) {

$query = "SELECT value FROM {$this->_sessionTable} WHERE sid = {$session_id} AND UNIX_TIMESTAMP(expiration) + " . self::SESSION_EXPIRE . " > UNIX_TIMESTAMP(NOW())";

$result = $this->_dbLink->query($query);

if(!isset($value) || empty($value)) {

$value = "";

return $value;

}

$this->_dbLink->query("UPDATE {$this->_sessionTable} SET expiration = CURRENT_TIMESTAMP() WHERE sid = {$session_id}");

$value = $result->fetch_array();

$result->free();

return $value['value'];

}

/**

* 寫入session

* @access public

* @param string $session_id session ID

* @param string $session_data session data

* @return integer

*/

public function write($session_id, $session_data) {

$query = "SELECT value FROM {$this->_sessionTable} WHERE sid = '{$session_id}' AND UNIX_TIMESTAMP(expiration) + " . self::SESSION_EXPIRE . " > UNIX_TIMESTAMP(NOW())";

$result = $this->_dbLink->query($query);

$result = $result->fetch_array();

if(!empty($result)) {

$result = $this->_dbLink->query("UPDATE {$this->_sessionTable} SET value = {$session_data} WHERE sid = {$session_id}");

}

else{

$result = $this->_dbLink->query("INSERT INTO {$this->_sessionTable} (sid, value) VALUES ('{$session_id}', '{$session_data}')");

}

if($result){

return 0;

}

else{

return 1;

}

}

/**

* 銷魂session

* @access public

* @param string $session_id session ID

* @return integer

*/

public function destroy($session_id) {

$result = $this->_dbLink->query("DELETE FROM {$this->_sessionTable} WHERE sid = '{$session_id}'");

if($result){

return 0;

}

else{

return 1;

}

}

/**

* 垃圾回收

* @access public

* @param string $maxlifetime session 最長生存時間

* @return integer

*/

public function gc($maxlifetime) {

$result = $this->_dbLink->query("DELETE FROM {$this->_sessionTable} WHERE UNIX_TIMESTAMP(expiration) < UNIX_TIMESTAMP(NOW()) - " . self::SESSION_EXPIRE);

if($result){

return 0;

}

else{

return 1;

}

}

}

/**********************************************************************************************************************************/

$dbLink = new mysqli("localhost", "root", "root", "test");

$sessionTable = "sessioninfo";

$handler = new MySessionHandler($dbLink, $sessionTable);

session_set_save_handler($handler);

session_start();

$_SESSION['name'] = "test";

echo $_SESSION["name"];

//session_destroy();

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機網(wǎng)站地址:PHP實現(xiàn)session信息存儲到數(shù)據(jù)庫

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)