session入库

1.为什么要实现session信息入库?

目的:为了方便对数据的管理,单个session不入库可以实现,可是一旦session要求存储的数据量较大的时候,那么这个时候就不方便了。所以选择入库

2.session入库实现的步骤:

  2.1建立一张数据表,用来存放session信息,字段有:session_id,session_data,time

3.封装session操作:

  1. <?php  
  2. ini_set("session.save_handler","user");  
  3. //session.gc_probability = 1 分子  
  4. ini_set("session.gc_probability",1);  
  5. //session.gc_divisor = 1000 分母  
  6. ini_set("session.gc_divisor",2);  
  7. //session.gc_maxlifetime = 1440 垃圾回收时间,session有效期  
  8.   
  9. session_set_save_handler( "open","close","read","write","destroy","gc" );//设置用户自定义会话存储函数及执行方法  
  10.   
  11. //连接数据库  
  12. function open(){  
  13.     @$link = mysql_connect('127.0.0.1''root''root');  
  14.     mysql_query('set names utf8');  
  15.     mysql_query('use session');  
  16. }  
  17. function close(){  
  18.     mysql_close();  
  19. }  
  20. function read($sess_id){  
  21.     $sql = "select session_data from `session` where session_id = '$sess_id'";  
  22.     $result = mysql_query($sql);  
  23.     if($rows = mysql_fetch_assoc($result)){  
  24.         return $rows['session_data']; }else{  
  25.         return '';  
  26.     }  
  27. }  
  28. function write($sess_id,$sess_data){  
  29.     $sql = "insert into `session` (session_id,session_data,session_time) values('$sess_id','$sess_data', now())  
  30. on duplicate key update session_data = '$sess_data' , session_time = now()  
  31. ";  //这是为了gc()  
  32.     return mysql_query($sql);  
  33. }  
  34. function destroy($sess_id){  
  35.     echo __FUNCTION__;  
  36.     $sql = "delete from `session` where session_id = '$sess_id'";  
  37.     return mysql_query($sql);  
  38. }  
  39. function gc($sess_id){  
  40.     echo __FUNCTION__;  
  41.     $sql = "delete from `session` where now()-session_time > '1440' ";  
  42.     return mysql_query($sql);  
  43. }  
  44. header("content-type:text/html;charset=utf8");  
  45. session_start();  
  46. $_SESSION['name']='haoyunyun';  
  47. $_SESSION['pwd']='123456';  
  48. $_SESSION['sex']='man';  
  49. //echo session_id();  
  50. echo $_SESSION['name'];  
  51. echo $_SESSION['pwd'];  
  52. echo $_SESSION['sex'];  
  53. ?>  

步骤详情:

  1. open(string $savePath, string $sessionName)  
  2.   
  3.    open 回调函数类似于类的构造函数, 在会话打开的时候会被调用。 这是自动开始会话或者通过调用 session_start() 手动开始会话 之后第一个被调用的回调函数。 此回调函数操作成功返回 TRUE,反之返回 FALSE。  

  1. close()  
  2.   
  3.    close 回调函数类似于类的析构函数。 在 write 回调函数调用之后调用。 当调用 session_write_close() 函数之后,也会调用 close 回调函数。 此回调函数操作成功返回 TRUE,反之返回 FALSE。  

  1. read(string $sessionId)  
  2.   
  3.    如果会话中有数据,read 回调函数必须返回将会话数据编码(序列化)后的字符串。 如果会话中没有数据,read 回调函数返回空字符串。  
  4.   
  5.    在自动开始会话或者通过调用 session_start() 函数手动开始会话之后,PHP 内部调用 read 回调函数来获取会话数据。 在调用 read 之前,PHP 会调用 open 回调函数。  
  6.   
  7.    read 回调返回的序列化之后的字符串格式必须与 write 回调函数保存数据时的格式完全一致。 PHP 会自动反序列化返回的字符串并填充 $_SESSION 超级全局变量。 虽然数据看起来和 serialize() 函数很相似, 但是需要提醒的是,它们是不同的。 请参考: session.serialize_handler。  

  1. write(string $sessionId, string $data)  
  2.   
  3.    在会话保存数据时会调用 write 回调函数。 此回调函数接收当前会话 ID 以及 $_SESSION 中数据序列化之后的字符串作为参数。 序列化会话数据的过程由 PHP 根据 session.serialize_handler 设定值来完成。  
  4.   
  5.    序列化后的数据将和会话 ID 关联在一起进行保存。 当调用 read 回调函数获取数据时,所返回的数据必须要和 传入 write 回调函数的数据完全保持一致。  
  6.   
  7.    PHP 会在脚本执行完毕或调用 session_write_close() 函数之后调用此回调函数。 注意,在调用完此回调函数之后,PHP 内部会调用 close 回调函数。  
  8.   
  9.        Note:  
  10.   
  11.        PHP 会在输出流写入完毕并且关闭之后 才调用 write 回调函数, 所以在 write 回调函数中的调试信息不会输出到浏览器中。 如果需要在 write 回调函数中使用调试输出, 建议将调试输出写入到文件。   

  1. destroy($sessionId)  
  2.   
  3.    当调用 session_destroy() 函数, 或者调用 session_regenerate_id() 函数并且设置 destroy 参数为 TRUE 时, 会调用此回调函数。此回调函数操作成功返回 TRUE,反之返回 FALSE。  

  1. gc($lifetime)  
  2.   
  3.    为了清理会话中的旧数据,PHP 会不时的调用垃圾收集回调函数。 调用周期由 session.gc_probability 和 session.gc_divisor 参数控制。 传入到此回调函数的 lifetime 参数由 session.gc_maxlifetime 设置。 此回调函数操作成功返回 TRUE,反之返回 FALSE。 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值