亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

將PHP的session數據存儲到數據庫中的代碼實例

2020-03-22 19:27:32
字體:
來源:轉載
供稿:網友
一個開發環境有多個網站,需要使用不同的session,解決方案很多。不過這次也高大上一把,用數據庫存,方便以后擴展。PostgreSQL版
首先是數據庫的部分--drop table php_sessioncreate unlogged table php_session sess_id varchar(32) primary key, modify_time timestamp with time zone not null, sess_data varchar(3000) default ''create index conhtml' target='_blank'>currently idx_php_session_modify_time on php_session(modify_time);--set_session(id, data)create or replace function set_session(varchar, varchar) returns void as $set_session$ with upsert as ( update php_session set modify_time = current_timestamp, sess_data = $2 where sess_id = $1 returning 1 insert into php_session (sess_id, modify_time, sess_data) select $1, current_timestamp, $2 where not exists ( select 1 from upsert$set_session$ language sql;--get_session(id)create or replace function get_session(varchar) returns varchar as $get_session$ select sess_data from php_session where sess_id = $1$get_session$ language sql;--del_sessioncreate or replace function del_session(varchar) returns void as $del_session$ delete from php_session where sess_id = $1$del_session$ language sql;--gc_sessioncreate or replace function gc_session() returns void as $del_session$ delete from php_session where modify_time current_timestamp - interval '30 days'$del_session$ language sql;然后是PHP的部分session_set_save_handler( function ($savePath, $sessionName) {//open return true; function () {//close return true; function ($id) {//read $sql = "select get_session($1)"; $stmt = pg_query_params(SESSION_CONN, $sql, array($id)); $result = pg_fetch_row($stmt); return $result[0]; function ($id, $data) {//write $sql = "select set_session($1, $2)"; pg_query_params(SESSION_CONN, $sql, array($id, $data)); return true; function ($id) {//destroy $sql = "select del_session($1)"; pg_query_params(SESSION_CONN, $sql, array($id, $data)); return true; function ($maxlifetime) {//gc //php needn't control the global session gc return true;register_shutdown_function('session_write_close');
然后只要在session_start之前調用這個就可以了至于SESSION_CONN,那是我定義的一個常量,表示一個指向session數據庫的鏈接而已。MySQL
再總結一個針對MySQL的集成更多基礎功能的例子:
表結構:
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;session信息存儲到數據庫的類:
class MySessionHandler implements SessionHandlerInterface { * @access private * @var object 數據庫連接 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; * 關閉 * @access public * @return integer public function close() { return 0; * 關閉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();PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国内精品400部情侣激情| 91精品国产91久久久久久不卡| 国产中文日韩欧美| 亚洲欧洲中文天堂| 高清欧美一区二区三区| 亚洲国产精品电影| 精品久久久久久久久久久久| 91精品国产综合久久久久久久久| 亚洲综合色激情五月| 欧美激情一区二区三级高清视频| 欧美怡红院视频一区二区三区| 日韩三级影视基地| 国产精品高清在线观看| 久久久亚洲成人| 国产精品老牛影院在线观看| 欧美日韩国产中文字幕| 色琪琪综合男人的天堂aⅴ视频| 国产成人jvid在线播放| 久久久电影免费观看完整版| 亚洲精品在线观看www| 亚洲伦理中文字幕| 欧美精品videos另类日本| 欧美日韩一区二区三区| 国产精品亚洲аv天堂网| 97人人爽人人喊人人模波多| 精品视频www| 色偷偷888欧美精品久久久| 91探花福利精品国产自产在线| 色婷婷久久一区二区| 成人黄色在线免费| 亚洲无av在线中文字幕| 欧美寡妇偷汉性猛交| 欧美精品在线观看91| 久久天天躁夜夜躁狠狠躁2022| 日韩av在线免费观看一区| 成人性教育视频在线观看| 日韩中文字幕在线精品| 中文字幕一区二区三区电影| 久久精品国亚洲| 国产伊人精品在线| 亚洲大胆美女视频| 91网站在线免费观看| 成人综合网网址| 91av视频在线免费观看| 欧美亚洲在线播放| 九九热最新视频//这里只有精品| 色伦专区97中文字幕| 成人中文字幕+乱码+中文字幕| 久久国产精品久久久久久| 琪琪亚洲精品午夜在线| 精品人伦一区二区三区蜜桃网站| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产精品久久久久久久久久东京| 在线亚洲欧美视频| 日韩美女福利视频| 亚洲一区二区三区在线免费观看| 日韩精品视频在线观看免费| 久久久久久美女| 欧美日韩在线影院| 精品国产美女在线| 日韩精品丝袜在线| 久久影视电视剧免费网站| 国产视频亚洲视频| 欧美电影《睫毛膏》| 热久久免费视频精品| 日韩va亚洲va欧洲va国产| 热久久免费国产视频| 欧美亚洲一区在线| 亚洲激情小视频| 黑人狂躁日本妞一区二区三区| 欧美猛少妇色xxxxx| 国产亚洲欧洲高清一区| 日韩资源在线观看| 久久在线免费观看视频| 亚洲欧洲黄色网| 亚洲精品美女久久久久| 伊人成人开心激情综合网| 久久欧美在线电影| 日韩国产在线看| 色偷偷av亚洲男人的天堂| 一本大道久久加勒比香蕉| 欧美性视频精品| 精品人伦一区二区三区蜜桃网站| zzijzzij亚洲日本成熟少妇| 日韩免费中文字幕| 欧美成人四级hd版| 国产精品精品一区二区三区午夜版| 久久五月情影视| 久久久国产精品x99av| 欧美福利视频网站| 插插插亚洲综合网| 久久国产精品视频| 久久久久久国产三级电影| 色一情一乱一区二区| 一区二区福利视频| 国产91精品网站| 欧美激情影音先锋| 亚洲人成电影网站色| 日韩在线播放视频| 国产成人高潮免费观看精品| 日韩精品免费电影| 色综合视频一区中文字幕| 精品亚洲夜色av98在线观看| 日韩亚洲第一页| 欧美成人国产va精品日本一级| 欧美高清视频在线观看| 亚洲另类激情图| 欧美麻豆久久久久久中文| 亚洲成人激情在线观看| 成人激情视频小说免费下载| 成人激情黄色网| 俺也去精品视频在线观看| 色婷婷综合成人av| 欧美香蕉大胸在线视频观看| 日韩国产在线播放| 日韩美女激情视频| 成人看片人aa| 欧美激情在线一区| 国产色综合天天综合网| 久久久免费av| 在线播放国产一区二区三区| 日韩在线精品一区| 91在线免费看网站| 欧美—级a级欧美特级ar全黄| 国产精品偷伦免费视频观看的| 精品久久香蕉国产线看观看gif| 国产伦精品免费视频| 成人国产精品久久久久久亚洲| 亚洲高清久久网| 黄色一区二区三区| 国产情人节一区| 久久精品亚洲94久久精品| 国产精品国产三级国产aⅴ9色| 国产精品亚洲第一区| 这里只有精品久久| 亚洲欧美日韩在线高清直播| 欧美激情免费看| 国产91露脸中文字幕在线| 亚洲三级黄色在线观看| 在线播放国产一区二区三区| 欧美电影免费观看电视剧大全| 久久国产精品99国产精| 亚洲欧美在线磁力| 国产精品91久久久久久| 亚洲精品福利资源站| 国产精品吴梦梦| 日韩精品亚洲元码| 国产亚洲成精品久久| 欧美午夜宅男影院在线观看| 一区二区欧美亚洲| 久久6精品影院| 日产日韩在线亚洲欧美| 欧美日韩福利电影| 亚洲а∨天堂久久精品9966| 欧美在线观看日本一区| 在线播放精品一区二区三区| 色播久久人人爽人人爽人人片视av| 国产精品激情av在线播放| 日韩免费视频在线观看| 69av成年福利视频| 日韩中文有码在线视频| 一区二区三区回区在观看免费视频| 亚洲最大中文字幕| 亚洲成av人影院在线观看|