当前位置:首页 > PHP > session自定义存储方式

session自定义存储方式

在php中session中的数据默认是以文件形式存储在磁盘上的,这对小型网站来说,可能已经可以满足要求了。大事对于大中型网站,或者一些有特殊需求的网站来说,默认的存储方式已经不能够满足要求了!他们需要自己定义session的存储方式,以便这些session中的数据可以在多台服务器之间共享!

对此php提供了一个函数来解决

bool session_set_save_handler ( string open, string close, string read, string write, string destroy, string gc )

函数中一个参数对应一个函数,函数的名称自定但参数为固定格式,没有用到也要。

一、open(string save_path, string session_name)为session_start 参数string save_path session存取路径string session_name传递session id的cookie名字。
function _session_open(string save_path, string name)
{
$db=mysql_connect(“localhost”,”root”,”123456″,”tendao”);
return TRUE;
}

二、close为session_close 无参数
在此对应关闭数据库,但一般网站中在此一般不要关闭。

三、read(key)为读取session键值。key对应session id。

四、write(key,date)其中的data对应设置的session变量,格式如下:
email_name|s:13:”qqtxt@163.com”;member_id|s:1:”1″;

五、destroy(key)注销session
在此程序段中对应删除对应记录项。

六、gc(expiry_time)清除过期session记录。

表的结构`session`

Create TABLE `session` (
`session_key` char(32) NOT NULL,
`session_data` char(255) NOT NULL,
`session_expiry` int(11) unsigned NOT NULL,
PRIMARY KEY (`session_key`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;字符集根据情况更改

class Session{
var $expiry=3600;
var $db;

function __construct(){
$this->Session();
}

function Session(){
session_set_save_handler( array (& $this, “_session_open”),
array (& $this, “_session_close”),
array (& $this, “_session_read”),
array (& $this, “_session_write”),
array (& $this, “_session_destroy”),
array (& $this, “_session_gc”)
);

}

/**
* open session handler
*
* @param string $save_path
* @param string $session_name
* @return boolen
*/
function _session_open($save_path, $session_name)
{
$this->db=mysql_connect(“localhost”,”root”,”123456″) or die(“数据库连接失败!”);
mysql_select_db(“tendao”,$this->db);
return TRUE;
}

function _session_close(){
return true;
}

function _session_read($key){
$expiry=time();
$s_query=sprintf(“select session_data from session where session_key= ‘%s’ and session_expiry > %d ” , $key, $expiry );
$result=mysql_query($s_query,$this->db);
$row=mysql_fetch_assoc($result);
if($row){
return $row['session_data'];
}
else
return FALSE;
}

function _session_write($key,$data){
$expiry_time=time()+$this->expiry;
$s_query=sprintf(“select session_data from session where session_key= ‘%s’”, $key);
$result=mysql_query($s_query,$this->db);
if(mysql_num_rows($result)==0){
$s_query=sprintf(“insert into session values(‘%s’,’%s’, %d)”,$key,$data,$expiry_time);
$result=mysql_query($s_query,$this->db);
}
else{
$s_query=sprintf(“update session set session_key=’%s’, session_data=’%s’,session_expiry=%d where session_key=’%s’”,$key,$data,$expiry_time,$key);
$result=mysql_query($s_query,$this->db);
}
return $result;
}

function _session_destroy($key){
$s_query=sprintf(“delete from session where session_key= ‘%s’”, $key);
$result=mysql_query($s_query,$this->db);
return $result;
}

function _session_gc($expiry_time){
$expiry_time=time();
$s_query=sprintf(“delete from session where session_expiry < %d", $expiry_time); $result=mysql_query($s_query,$this->db);
return $result;
}
}

$_ses_=new Session();
session_start();

$_SESSION['time']=time()+1200;
echo strval(time()).’
‘.strval($_SESSION['time']);
?>

<?php
header('content-type:text/html;charset=utf-8');
ini_set('session.gc_probability',1);
ini_set('session.gc_divisor',1000);
//ini_set('session.gc_maxlifetime',10);
class Session{
    var $expiry=300;
    var $db;
 
    public function __construct()
    {
        $this->db=mysql_connect("localhost","root","admin888") or die("数据库连接失败!");
        mysql_select_db("test",$this->db);  
 
    }
 
    public function start()
    {
        session_set_save_handler(
            array (& $this, "_session_open"),
            array (& $this, "_session_close"),
            array (& $this, "_session_read"),
            array (& $this, "_session_write"),
            array (& $this, "_session_destroy"),
            array (& $this, "_session_gc")
        );
    }
 
    /**
    * open session handler
    *
    * @param string $save_path
    * @param string $session_name
    * @return boolen
    */
    public function _session_open($save_path, $session_name)
    {
        $this->db=mysql_connect("localhost","root","admin888") or die("数据库连接失败!");
        mysql_select_db("test",$this->db);
        return TRUE;
    }
 
    public function _session_close()
    {
        return true;
    }
 
    public function _session_read($key){
        $expiry=time();
        $s_query=sprintf("select session_data from session where session_id= '%s' and session_expiry > %d " , $key, $expiry );
        $result=mysql_query($s_query,$this->db);
        $row=mysql_fetch_assoc($result);
        if($row)
        {
            return $row['session_data'];
        }
        else
            return FALSE;
    }
 
    public function _session_write($key,$data)
    {
        $uid = isset($_REQUEST['user_id']) ? $_REQUEST['user_id'] : '';
        if(empty($uid))
        {
            return false;
        }
        $expiry_time=time()+$this->expiry;
        $s_query=sprintf("select session_data from session where session_id= '%s'", $key);
        $result=mysql_query($s_query,$this->db);
        if(mysql_num_rows($result)==0)
        {
            $s_query=sprintf("insert into session values('%s','%s', %d,%d)",$key,$data,$expiry_time,$uid);
            $result=mysql_query($s_query,$this->db);
        }
        else
        {
            $s_query=sprintf("update session set session_id='%s', session_data='%s',session_expiry=%d where session_id='%s'",$key,$data,$expiry_time,$key);
            $result=mysql_query($s_query,$this->db);
        }
        return $result;
    }
 
    public function _session_destroy($key)
    {
        $s_query=sprintf("delete from session where session_id= '%s'", $key);
        $result=mysql_query($s_query,$this->db);
        return $result;
    }
 
    public function _session_gc($expiry_time)
    {
        $expiry_time=time();
        $s_query=sprintf("delete from session where session_expiry < %d", $expiry_time);
        $result=mysql_query($s_query,$this->db);
        echo '############';
        return $result;
    }
 
 
    public function fetch_row(){
        $uid = isset($_REQUEST['user_id']) ? $_REQUEST['user_id'] : '';
        if(empty($uid))
        {
            return false;
        }
        $expiry=time();
        $s_query=sprintf("select * from session where user_id= %d and session_expiry > %d " , $uid, $expiry );
        $result=mysql_query($s_query,$this->db);
        $row=mysql_fetch_assoc($result);
        if($row)
        {
            return $row;
        }
        else
            return FALSE;
    }
}
 
$_ses_=new Session();
$res = $_ses_->fetch_row();
if(is_array($res) && !empty($res))
{
    echo '您已在别处登录,请勿重复登录!';
    die;
}
$_ses_->start();
session_start();
$_SESSION['user_info']= array(
    'name' => '付鹏',
    'sex' => '女',
    'age' => 18
);
echo strval(time()).'
';
var_dump($_SESSION['user_info']);
//session_destroy();

 

sql语句

CREATE TABLE `session` (
  `session_id` char(32) NOT NULL COMMENT '会话id',
  `session_data` char(255) NOT NULL COMMENT 'session内容',
  `session_expiry` int(11) NOT NULL COMMENT '有效期',
  `user_id` int(11) NOT NULL,
  PRIMARY KEY (`session_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

 

  • «
  • »
  • 作者:
    除非注明,本文原创:OpenFree,专注于IT互联网,欢迎转载!转载请以链接形式注明本文地址,谢谢。
    原文链接:http://www.it163.org/post/session自定义存储方式

    发表评论

    电子邮件地址不会被公开。 必填项已用*标注


    您可以使用这些HTML标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>