session改写mysql

在调用 session_start();的地方改用实例化本类即可new SessionDB();

 session_set_save_handler(
array($this, 'userSessionBegin'),
array($this, 'userSessionEnd'),
array($this, 'userSessionRead'),
array($this, 'userSessionWrite'),
array($this, 'userSessionDelete'),
array($this, 'userSessionGC')
);如果是类里要这样写,因为要明确是哪个类的方法如果在类外可以这样写

session_set_save_handler(
'userSessionBegin',
'userSessionEnd',
'userSessionRead',
'userSessionWrite',
'userSessionDelete',
'userSessionGC')

<?php

/**
* session入库工具类
*/
class SessionDB {
private $_dao; public function __construct() {
//设置session处理器
ini_set('session.save_handler', 'user');
session_set_save_handler(
array($this, 'userSessionBegin'),
array($this, 'userSessionEnd'),
array($this, 'userSessionRead'),
array($this, 'userSessionWrite'),
array($this, 'userSessionDelete'),
array($this, 'userSessionGC')
); //开启
session_start();
} function userSessionBegin() {
//初始化DAO
$config = array('host' => '127.0.0.1', 'port' => '3306', 'username'=>'shop34', 'password' => '1234abcd', 'charset'=>'utf8', 'dbname'=>'shop34');
$this->_dao = MySQLDB::getInstance($config);
}
function userSessionEnd() {
return true;
}
/**
* 读操作
* 执行时机: session机制开启程中执行
* 工作: 从当前session数据区读取内容
* @param $sess_id string
* @return string
*/
function userSessionRead($sess_id) {
//查询
$sql = "SELECT session_content FROM `p34_session` WHERE session_id='$sess_id'";
return (string) $this->_dao->getOne($sql);
}
/**
* 写操作
* 执行时机: 脚本周期结束时,PHP在整理收尾时
* 工作: 将当前脚本处理好的session数据,持久化存储到数据库中!
* @param $sess_id string
* @param $sess_content string 序列化好的session内容字符串
* @return bool
*/
function userSessionWrite($sess_id, $sess_content) {
// 完成写
$sql = "REPLACE INTO `p34_session` VALUES ('$sess_id', '$sess_content', unix_timestamp())";
return $this->_dao->query($sql);
}
/**
* 删除操作
* 执行时机: 调用了session_destroy()销毁session过程中被调用
* 工作: 删除当前session的数据区(记录)
* @param $sess_id string
* @return bool
*/
function userSessionDelete($sess_id) {
//删除
$sql = "DELETE FROM `p34_session` WHERE session_id='$sess_id'";
return $this->_dao->query($sql);
}
/**
* 垃圾回收操作
* 执行时机: 开启session机制时,有概率的执行
* 工作: 删除那些过期的session数据区
* @param $max_lifetime
* @return bool
*/
function userSessionGC($max_lifetime) {
//删除
$sql = "DELETE FROM `p34_session` WHERE last_time<unix_timestamp()-$max_lifetime";
return $this->_dao->query($sql);
} }

gc回收器调用次数改写

ini_set('session.gc_probability', '1');
ini_set('session.gc_divisor', '3');
//session.gc_divisor 与 session.gc_probability 合起来定义了在每个会话初始化时启动 gc(garbage collection 垃圾回收)进程的概率。此概率用 gc_probability/gc_divisor 计算得来。例如 1/100 意味着在每个请求中有 1% 的概率启动 gc 进程。session.gc_divisor 默认为 100。

最新文章

  1. AC算法学习笔记
  2. Linux CentOS 中安装 MySql
  3. thinkphp3.2!Go for it!
  4. 每天一个 Linux 命令(8):cp 命令
  5. web开发中的 emmet 效率提升工具
  6. Hark的数据结构与算法练习之若领图排序ProxymapSort
  7. Qwt 折线图 波形图 柱状图示例效果
  8. HDU 5791 Two
  9. WebService的相关使用
  10. Swift基础之Swift调用OC语言文件使用步骤
  11. 【Java每日一题】20170323
  12. python之路--MySQL数据库初识
  13. Confluence 6 订阅所应用的所有小工具
  14. Waf-Bypass-Learning
  15. 解决Anaconda4.2 Navigator打不开的问题
  16. esLint参数设置
  17. Linux笔记 #06# 在VPS上自建Git服务
  18. Redis主从复制(Master/Slave) 与哨兵模式
  19. 51nod1380 夹克老爷的逢三抽一
  20. 二十八 Python分布式爬虫打造搜索引擎Scrapy精讲—cookie禁用、自动限速、自定义spider的settings,对抗反爬机制

热门文章

  1. oldboy第五天学习
  2. 随机数(random)
  3. 温故而知新 C++ 数组与指针
  4. poj 1364
  5. SSH的内网穿透
  6. 【动态规划】XMU 1030 苦恼的月下老人
  7. jsoup web scraping
  8. Java学习日记-2.1 运算符
  9. 基本 vi 命令
  10. Spring 3.2 ClassMetadataReadingVisitor 错误