把session存儲(chǔ)在數(shù)據(jù)庫(kù)中

通過(guò)session_set_save_handler(string open,string close,string read,string write,string destory,string gc)鳍贾。

(1)open(save path ,session_name)----找到session存儲(chǔ)的地址,
(2)close()------關(guān)閉數(shù)據(jù)庫(kù)
(3)read(key)-------讀取session值蕉饼,key對(duì)應(yīng)session_id
(4)write(key,data)------data對(duì)應(yīng)設(shè)置的session變量
(5)destory(key)------注銷session對(duì)應(yīng)的
(6)gc(expriy_time)------清除過(guò)期的session
簡(jiǎn)單應(yīng)用

<?php
$con = mysql_connect("127.0.0.1", "user" , "pass");
mysql_select_db("session");
function open($save_path, $session_name) {
    return(true);
}
function close() {
    return(true);
}
function read($id) {
    if ($result = mysql_query("select * from session where id='$id'")) {
        if ($row = mysql_felth_row($result)) {
            return $row["data"];
        }
    } else {
        return "";
    }
}
function write($id, $sess_data) {
    if ($result = mysql_query("update session set data='$sess_data' where id='$id'")) {
        return true;
    } else {
        return false;
    }
}
function destroy($id) {
    if ($result = mysql_query("delete * from session where id='$id'")) {
        return true;
    } else {
        return false;
    }
}
function gc($maxlifetime) {
    return true;
}
session_set_save_handler("open", "close", "read", "write", "destroy", "gc");
session_start();
// proceed to use sessions normally

實(shí)際案例

<?php
/**
 * SessionMysql 數(shù)據(jù)庫(kù)存儲(chǔ)類
 */

defined('IN_QIAN') or exit('Access Denied');

class SessionMysql {

    public $lifetime = 1800; // 有效期拷泽,單位:秒(s)贺待,默認(rèn)30分鐘
    public $db;
    public $table;

    /**
     * 構(gòu)造函數(shù)
     */
    public function __construct() {
        $this->db = Base::loadModel('SessionModel');
        $this->lifetime = Base::loadConfig('system', 'session_lifetime');
        session_set_save_handler(
            array(&$this, 'open'),      // 在運(yùn)行session_start()時(shí)執(zhí)行
            array(&$this, 'close'),     // 在腳本執(zhí)行完成 或 調(diào)用session_write_close() 或 session_destroy()時(shí)被執(zhí)行,即在所有session操作完后被執(zhí)行
            array(&$this, 'read'),      // 在運(yùn)行session_start()時(shí)執(zhí)行,因?yàn)樵趕ession_start時(shí)除抛,會(huì)去read當(dāng)前session數(shù)據(jù)
            array(&$this, 'write'),     // 此方法在腳本結(jié)束和使用session_write_close()強(qiáng)制提交SESSION數(shù)據(jù)時(shí)執(zhí)行
            array(&$this, 'destroy'),   // 在運(yùn)行session_destroy()時(shí)執(zhí)行
            array(&$this, 'gc')         // 執(zhí)行概率由session.gc_probability 和 session.gc_divisor的值決定薯酝,時(shí)機(jī)是在open半沽,read之后,session_start會(huì)相繼執(zhí)行open吴菠,read和gc
        );
        session_start(); // 這也是必須的者填,打開session,必須在session_set_save_handler后面執(zhí)行
    }
    /**
     * session_set_save_handler open方法
     *
     * @param $savePath
     * @param $sessionName
     * @return true
     */
    public function open($savePath, $sessionName) {
        return true;
    }
    /**
     * session_set_save_handler close方法
     *
     * @return bool
     */
    public function close() {
        return $this->gc($this->lifetime);
    }
    /**
     * 讀取session_id
     *
     * session_set_save_handler read方法
     * @return string 讀取session_id
     */
    public function read($sessionId) {
        $condition = array(
            'where' => array(
                'session_id' => $sessionId
            ),
            'fields' => 'data'
        );
        $row = $this->db->fetchFirst($condition);
        return $row ? $row['data'] : '';
    }
    /**
     * 寫入session_id 的值
     *
     * @param $sessionId 會(huì)話ID
     * @param $data 值
     * @return mixed query 執(zhí)行結(jié)果
     */
    public function write($sessionId, $data) {
        $userId = isset($_SESSION['userId']) ? $_SESSION['userId'] : 0;
        $roleId = isset($_SESSION['roleId']) ? $_SESSION['roleId'] : 0;
        $grouId = isset($_SESSION['grouId']) ? $_SESSION['grouId'] : 0;
        $m = defined('ROUTE_M') ? ROUTE_M : '';
        $c = defined('ROUTE_C') ? ROUTE_C : '';
        $a = defined('ROUTE_A') ? ROUTE_A : '';
        if (strlen($data) > 255) {
            $data = '';
        }
        $ip = get_ip();
        $sessionData = array(
            'session_id'    => $sessionId,
            'user_id'       => $userId,
            'ip'            => $ip,
            'last_visit'    => SYS_TIME,
            'role_id'       => $roleId,
            'group_id'      => $grouId,
            'm'             => $m,
            'c'             => $c,
            'a'             => $a,
            'data'          => $data,
        );
        return $this->db->insert($sessionData, 1, 1);
    }
    /**
     * 刪除指定的session_id
     *
     * @param string $sessionId 會(huì)話ID
     * @return bool
     */
    public function destroy($sessionId) {
        return $this->db->delete(array('session_id' => $sessionId));
    }
    /**
     * 刪除過(guò)期的 session
     *
     * @param $lifetime session有效期(單位:秒)
     * @return bool
    */
    public function gc($lifetime) {
        $expireTime = SYS_TIME - $lifetime;
        return $this->db->delete("`last_visit`<$expireTime");
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末做葵,一起剝皮案震驚了整個(gè)濱河市占哟,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌酿矢,老刑警劉巖榨乎,帶你破解...
    沈念sama閱讀 223,126評(píng)論 6 520
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異瘫筐,居然都是意外死亡蜜暑,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,421評(píng)論 3 400
  • 文/潘曉璐 我一進(jìn)店門策肝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)肛捍,“玉大人,你說(shuō)我怎么就攤上這事之众∽竞粒” “怎么了?”我有些...
    開封第一講書人閱讀 169,941評(píng)論 0 366
  • 文/不壞的土叔 我叫張陵棺禾,是天一觀的道長(zhǎng)缀蹄。 經(jīng)常有香客問(wèn)我,道長(zhǎng)帘睦,這世上最難降的妖魔是什么袍患? 我笑而不...
    開封第一講書人閱讀 60,294評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮竣付,結(jié)果婚禮上诡延,老公的妹妹穿的比我還像新娘。我一直安慰自己古胆,他們只是感情好肆良,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,295評(píng)論 6 398
  • 文/花漫 我一把揭開白布筛璧。 她就那樣靜靜地躺著,像睡著了一般惹恃。 火紅的嫁衣襯著肌膚如雪夭谤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,874評(píng)論 1 314
  • 那天巫糙,我揣著相機(jī)與錄音朗儒,去河邊找鬼。 笑死参淹,一個(gè)胖子當(dāng)著我的面吹牛醉锄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播浙值,決...
    沈念sama閱讀 41,285評(píng)論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼恳不,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了开呐?” 一聲冷哼從身側(cè)響起烟勋,我...
    開封第一講書人閱讀 40,249評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎筐付,沒(méi)想到半個(gè)月后卵惦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,760評(píng)論 1 321
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡家妆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,840評(píng)論 3 343
  • 正文 我和宋清朗相戀三年鸵荠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片伤极。...
    茶點(diǎn)故事閱讀 40,973評(píng)論 1 354
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蛹找,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出哨坪,到底是詐尸還是另有隱情庸疾,我是刑警寧澤,帶...
    沈念sama閱讀 36,631評(píng)論 5 351
  • 正文 年R本政府宣布当编,位于F島的核電站届慈,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏忿偷。R本人自食惡果不足惜金顿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,315評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鲤桥。 院中可真熱鬧揍拆,春花似錦、人聲如沸茶凳。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,797評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至筒狠,卻和暖如春猪狈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背辩恼。 一陣腳步聲響...
    開封第一講書人閱讀 33,926評(píng)論 1 275
  • 我被黑心中介騙來(lái)泰國(guó)打工雇庙, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人运挫。 一個(gè)月前我還...
    沈念sama閱讀 49,431評(píng)論 3 379
  • 正文 我出身青樓状共,卻偏偏與公主長(zhǎng)得像套耕,于是被迫代替她去往敵國(guó)和親谁帕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,982評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容