-
PHP将session信息存储到数据库的类实例
这篇文章主要介绍了PHP将session信息存储到数据库的类,实例分析了php封装的session信息存储到数据库的类,具有一定参考借鉴价值,需要的朋友可以参考下。
本文实例讲述了PHP将session信息存储到数据库的类,分享给大家供大家参考,具体分析如下:
SessionHandlerInterface接口是PHP内置的接口,直接实现就行了
具体可以看php手册关于session_set_save_handler函数的解释!
PHP代码如下:
- /**
- * session信息存储到数据库的类
- * 表结构:
- * CREATE TABLE IF NOT EXISTS `sessioninfo` (
- * `sid` varchar(255) NOT NULL,
- * `value` text NOT NULL,
- * `expiration` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
- * PRIMARY KEY (`sid`)
- * ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
- */
- class MySessionHandler implements SessionHandlerInterface {
- /**
- * @access private
- * @var object 数据库连接
- */
- private $_dbLink;
- /**
- * @access private
- * @var string 保存session的表名
- */
- Private $_sessionTable;
- /**
- * @access private
- * @var string session名
- */
- private $_sessionName;
- /**
- * @const 过期时间
- */
- const SESSION_EXPIRE = 10;
- public function __construct($dbLink, $sessionTable) {
- if(!is_object($dbLink)) {
- return false;
- }
- $this->_dbLink = $dbLink;
- $this->_sessionTable = $sessionTable;
- }
- /**
- * 打开
- * @access public
- * @param string $session_save_path 保存session的路径
- * @param string $session_name session名
- * @return integer
- */
- public function open($session_save_path, $session_name) {
- $this->_sessionName = $session_name;
- return 0;
- }
- /**
- * 关闭
- * @access public
- * @return integer
- */
- public function close() {
- return 0;
- }
- /**
- * 关闭session
- * @access public
- * @param string $session_id session ID
- * @return string
- */
- public function read($session_id) {
- $query = "SELECT value FROM {$this->_sessionTable} WHERE sid = {$session_id} AND UNIX_TIMESTAMP(expiration) + " . self::SESSION_EXPIRE . " > UNIX_TIMESTAMP(NOW())";
- $result = $this->_dbLink->query($query);
- if(!isset($value) || emptyempty($value)) {
- $value = "";
- return $value;
- }
- $this->_dbLink->query("UPDATE {$this->_sessionTable} SET expiration = CURRENT_TIMESTAMP() WHERE sid = {$session_id}");
- $value = $result->fetch_array();
- $result->free();
- return $value['value'];
- }
- /**
- * 写入session
- * @access public
- * @param string $session_id session ID
- * @param string $session_data session data
- * @return integer
- */
- public function write($session_id, $session_data) {
- $query = "SELECT value FROM {$this->_sessionTable} WHERE sid = '{$session_id}' AND UNIX_TIMESTAMP(expiration) + " . self::SESSION_EXPIRE . " > UNIX_TIMESTAMP(NOW())";
- $result = $this->_dbLink->query($query);
- $result = $result->fetch_array();
- if(!emptyempty($result)) {
- $result = $this->_dbLink->query("UPDATE {$this->_sessionTable} SET value = {$session_data} WHERE sid = {$session_id}");
- }
- else{
- $result = $this->_dbLink->query("INSERT INTO {$this->_sessionTable} (sid, value) VALUES ('{$session_id}', '{$session_data}')");
- }
- if($result){
- return 0;
- }
- else{
- return 1;
- }
- }
- /**
- * 销魂session
- * @access public
- * @param string $session_id session ID
- * @return integer
- */
- public function destroy($session_id) {
- $result = $this->_dbLink->query("DELETE FROM {$this->_sessionTable} WHERE sid = '{$session_id}'");
- if($result){
- return 0;
- }
- else{
- return 1;
- }
- }
- /**
- * 垃圾回收
- * @access public
- * @param string $maxlifetime session 最长生存时间
- * @return integer
- */
- public function gc($maxlifetime) {
- $result = $this->_dbLink->query("DELETE FROM {$this->_sessionTable} WHERE UNIX_TIMESTAMP(expiration) < UNIX_TIMESTAMP(NOW()) - " . self::SESSION_EXPIRE);
- if($result){
- return 0;
- }
- else{
- return 1;
- }
- }
- }
- $dbLink = new mysqli("localhost", "root", "root", "test");
- $sessionTable = "sessioninfo";
- $handler = new MySessionHandler($dbLink, $sessionTable);
- session_set_save_handler($handler);
- session_start();
- $_SESSION['name'] = "test";
- echo $_SESSION["name"];
- //session_destroy();
出处:http://www.phpfensi.com/php/20210515/15340.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式