SESSION存放在数据库用法实例

5年以前  |  阅读数:511 次  |  编程语言:PHP 

本文实例讲述了SESSION存放在数据库用法。分享给大家供大家参考。具体如下:


    <?php
    /*
    CREATE TABLE `ws_sessions` (
     `session_id` varchar(255) binary NOT NULL default '',
     `session_expires` int(10) unsigned NOT NULL default '0',
     `session_data` text,
     PRIMARY KEY (`session_id`)
    ) TYPE=InnoDB;
    */
    class session {
     // session-lifetime
     var $lifeTime;
     // mysql-handle
     var $dbHandle;
     function open($savePath, $sessName) {
     // get session-lifetime
     $this->lifeTime = get_cfg_var("session.gc_maxlifetime");
     // open database-connection
     $dbHandle = @mysql_connect("localhost","root","");
     $dbSel = @mysql_select_db("test",$dbHandle);
     // return success
     if(!$dbHandle || !$dbSel)
      return false;
     $this->dbHandle = $dbHandle;
     return true;
     }
     function close() {
     $this->gc(ini_get('session.gc_maxlifetime'));
     // close database-connection
     return @mysql_close($this->dbHandle);
     }
     function read($sessID) {
     // fetch session-data
     $res = mysql_query("SELECT session_data AS d FROM ws_sessions
        WHERE session_id = '$sessID'
        AND session_expires > ".time(),$this->dbHandle);
     // return data or an empty string at failure
     if($row = mysql_fetch_assoc($res))
      return $row['d'];
     return "";
     }
     function write($sessID,$sessData) {
     // new session-expire-time
     $newExp = time() + $this->lifeTime;
     // is a session with this id in the database?
     $res = mysql_query("SELECT * FROM ws_sessions
        WHERE session_id = '$sessID'",$this->dbHandle);
     // if yes,
     if(mysql_num_rows($res)) {
      // ...update session-data
      mysql_query("UPDATE ws_sessions
        SET session_expires = '$newExp',
        session_data = '$sessData'
        WHERE session_id = '$sessID'",$this->dbHandle);
      // if something happened, return true
      if(mysql_affected_rows($this->dbHandle))
      return true;
     }
     // if no session-data was found,
     else {
      // create a new row
      mysql_query("INSERT INTO ws_sessions (
        session_id,
        session_expires,
        session_data)
        VALUES(
        '$sessID',
        '$newExp',
        '$sessData')",$this->dbHandle);
      // if row was created, return true
      if(mysql_affected_rows($this->dbHandle))
      return true;
     }
     // an unknown error occured
     return false;
     }
     function destroy($sessID) {
     // delete session-data
     mysql_query("DELETE FROM ws_sessions WHERE session_id = '$sessID'",$this->dbHandle);
     // if session was deleted, return true,
     if(mysql_affected_rows($this->dbHandle))
      return true;
     // ...else return false
     return false;
     }
     function gc($sessMaxLifeTime) {
     // delete old sessions
     mysql_query("DELETE FROM ws_sessions WHERE session_expires < ".time(),$this->dbHandle);
     // return affected rows
     return mysql_affected_rows($this->dbHandle);
     }
    }
    $session = new session();
    session_set_save_handler(array(&$session,"open"),
        array(&$session,"close"),
        array(&$session,"read"),
        array(&$session,"write"),
        array(&$session,"destroy"),
        array(&$session,"gc"));
    session_start();
    // etc...
    ?>

希望本文所述对大家的php程序设计有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例