欢迎投稿

今日深度:

session入库

session入库


session_set_save_handler(callback open,callback close,callback read,call write,callback destroy,callback gc)

 

各个参数的的执行时机以及使用说明

回调函数

描述

open()

在运行session_start()时执行,该函数的声明需要两个参数,系统会自动的将php.ini中session.save_path选项值传递给第一个参数,将session名自动的传递到第二个参数中,返回true则继续往下执行

close()

该函数不需要参数,在脚本执行完成或调用session_write_close(),session_destroy()时被执行,即在所有session操作完成后被执行,如果不需要处理直接返回true

read()

在运行session_start()时执行,因为在开启会话时,会去read当前的session数据并且写入$_SESSION变量。需要声明一个参数,系统会自动的将SessionId传递给该函数,用于通过sessionId获取对应的用户数据,返回当前的用户数据写入$_SESSION数据

write()

该函数在脚本结束和对$_SESSION变量赋值时执行,需要声明两个参数,分别是sessionid和串行化后session信息字符串,在对$_SESSION变量赋值时,就可以通过Sessionid找到存储位置,并且将信息写入,存储成功可以返回true继续向下执行

 

destroy()

在运行session_destroy时执行,需要声明一个参数,系统会自动将sessionId传递给该函数,去除对应的回话信息

gc()

垃圾回收程序启动时执行。需要声明一个参数,系统自动将php.ini中

session.gc_maxlifetime选项的值传递给该函数,用户删除超过这个时间的session信息,返回true可以继续向下执行

 

Session入库就是将session的信息保存到表中,需要设置session.save_handler = user

 

新建session表

DROP TABLE IF EXISTS `session`;

CREATE TABLE `session` (

`sid` char(32) NOT NULL,

`update_time` int(11) default NULL,

`data` text,

PRIMARY KEY (`sid`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

需要存储 sessionid ,更新时间,格式化数据

 

然后写功能性代码:

$link=mysql_connect("127.0.0.1","root","root");

mysql_select_db("session");

mysql_query("set names utf8");



function open($save_path,$session_name){

return true;

}



function close(){

return true;

}



function read($sid){



/*通过sid先从数据库中查找当前用户的信息*/

$sql="select * from session where sid='$sid'";

//echo $sql;

$re=mysql_query($sql);

/*如果没有结果返回空字符串给$_SESSION变量*/

if(!$result=mysql_fetch_array($re)){

return "";

}

/*如果有数据返回结果*/



return $result["data"];

}



function write($sid,$data){



/*每次写之前先从数据库中获取一下是否已经存在该用户的session信息*/

$sql="select * from session where sid='$sid'";

$re=mysql_query($sql);

$time=time();

/*如果存在该用户的信息则去修改,如果不存在要重新添加一行数据*/

if($result=mysql_fetch_array($re)){

//存在的情况

$sql1="update session set update_time='$time',data='$data' where sid='$sid'";

mysql_query($sql1);

}else{

//不存在的情况

if(!empty($data)){

$sql1="insert into session(sid,update_time,data) values('$sid','$time','$data')";

$sth1=mysql_query($sql1);



}

}

return true;



}



function destroy($sid){

//通过sessionid来删除当前用户的记录

$sql="delete from session where sid='$sid'";

mysql_query($sql);

return true;

}



function gc($maxfiletime){

//通过sessionid来删除当前用户的记录

$sql="delete * from session where update_time<$maxfiletime";

mysql_query($sql);

return true;



}

session_set_save_handler("open","close","read","write","destroy","gc");

session_start();

?>

 

www.htsjk.Com true http://www.htsjk.com/DB2/20312.html NewsArticle session入库 session_set_save_handler(callback open,callback close,callback read,call write,callback destroy,callback gc) 各个参数的的执行时机以及使用说明 回调函数 描述 open() 在运行session_start()时执行,该函数...
相关文章
    暂无相关文章
评论暂时关闭