php使用MySQL保存session会话的方法


Posted in PHP onJune 18, 2015

本文实例讲述了php使用MySQL保存session会话的方法。分享给大家供大家参考。具体分析如下:

在很多大的系统中一般都有这个功能,但是要分离出来分析,网上靠谱的资料也不太多 这里我整理了一篇发出来与大家分享

使用MySQL保存session会话较files有很多优点:

1) 有利于分布式系统,files只能保存在一台机器上
2) 有利于大访问量的系统,使用files时每个session保存在一个文件中,目录会超级大,查找session文件会比较困难。

//////使用MySQL保存会话首先要创建session表:
<?php
$hostname_login = "localhost"; // Server address
$username_login = "root"; // User name 
$password_login = ""; // Password
//
$data_name = "session"; // Database name
$login = mysql_pconnect($hostname_login, $username_login, $password_login) or trigger_error(mysql_error(),E_USER_ERROR); 
$sql="SHOW DATABASES LIKE '".$data_name."'"; // If it is exist
if($rs_table=mysql_query($sql,$login)) { 
 if($rs_value=mysql_fetch_array($rs_table)) { 
  echo "数据库已经存在!\n!";
  exit(); 
 } 
}
$sql="CREATE DATABASE $data_name";  
mysql_query($sql); // Crate database
echo "数据库创建成功!\n"; 
mysql_select_db($data_name, $login);
$sql="CREATE TABLE `sessions` ( 
`SessionKey` varchar(32) NOT NULL default '', 
`SessionArray` blob NOT NULL, 
`SessionExpTime` int(20) unsigned NOT NULL default '0', 
PRIMARY KEY (`SessionKey`), 
KEY `SessionKey` (`SessionKey`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8"; //新建数据库 sql语句
mysql_query($sql);
echo "成功新建数据库表!";
?>
/////////MysqlSession 类如下:
<?php 
class MysqlSession {
// 注意在有使用Session的页面。页面一定要顶格,页面开始处不能留空。
private $DB_SERVER = "localhost"; // 数据库服务器主机名
 private $DB_NAME = ""; // 数据库名字
 private $DB_USER = "root";  // MYSQL 数据库访问用户名 
 private $DB_PASS = "";  // MYSQL 数据库访问密码 
 private $DB_SELECT_DB = ""; 
//private $SESS_LIFE = 1440;  // Session的最大使用时长,单位秒。
private $SESS_LIFE = 0;
function MysqlSession (&$sessionDB) {
 //session_write_close();
 $this->DB_NAME = &$sessionDB;
 $this->SESS_LIFE = get_cfg_var("session.gc_maxlifetime");
 session_module_name('user');
 session_set_save_handler( 
 array(&$this, 'sess_open'), 
 array(&$this, 'sess_close'), 
 array(&$this, 'sess_read'), 
 array(&$this, 'sess_write'), 
 array(&$this, 'sess_destroy'), 
 array(&$this, 'sess_gc') 
 );
 session_start();
}
function sess_open($save_path, $session_name){ // 打开数据库连接
 if (! $this->DB_SELECT_DB = mysql_pconnect($this->DB_SERVER, $this->DB_USER, $this->DB_PASS)) { 
 echo "SORRY! MYSQL ERROR : Can't connect to $this->DB_SERVER as $DB_USER"; 
 echo "MySQL Error: ", mysql_error(); 
 die; 
 } 
 if (! mysql_select_db($this->DB_NAME, $this->DB_SELECT_DB)) { 
 echo "SORRY! MYSQL ERROR : Unable to select database $this->DB_NAME"; 
 die; 
 } 
 return true; 
} 
function sess_close() { 
  return true; 
} 
function sess_read($SessionKey){ 
  $Query = "SELECT SessionArray FROM sessions WHERE SessionKey = '".$SessionKey."' AND SessionExpTime > " . time();
  // 过期不读取。
  $Result = mysql_query($Query, $this->DB_SELECT_DB); 
 if (list($SessionArray) = mysql_fetch_row($Result)) { 
   return $SessionArray; 
 } 
 return false; 
} 
function sess_write($SessionKey, $VArray) { 
 $SessionExpTime = time() + $this->SESS_LIFE;
 // 更新Session过期时间,
 //Session过期时间 = 最后一次更新时间 + Session的最大使用时长
 $SessionArray = addslashes($VArray); 
 $Query = "INSERT INTO sessions (SessionKey,SessionExpTime,SessionArray) VALUES ('".$SessionKey."','".$SessionExpTime."','".$SessionArray."')"; 
 $Result = mysql_query($Query, $this->DB_SELECT_DB); 
 if (!$Result){ 
   $Query = "UPDATE sessions SET SessionExpTime = '".$SessionExpTime."', SessionArray = '".$SessionArray."' WHERE SessionKey = '".$SessionKey."' AND SessionExpTime > " . time(); 
   $Result = mysql_query($Query, $this->DB_SELECT_DB); 
 } 
 return $Result; 
} 
function sess_destroy($SessionKey) { 
 $Query = "DELETE FROM sessions WHERE SessionKey = '".$SessionKey."'"; 
 $Result = mysql_query($Query, $this->DB_SELECT_DB); 
 return $Result; 
} 
function sess_gc($maxlifetime) {
// 这个垃圾清除器系统调用。
//默认是1440秒清除一次。参数可以在PHP.ini里面设置。
 $Query = "DELETE FROM sessions WHERE SessionExpTime < " . time(); 
 $Result = mysql_query($Query, $this->DB_SELECT_DB); 
 return mysql_affected_rows($this->DB_SELECT_DB); 
} 
}
?>
//用法:在原来使用 session_start 的地方,替换成 $session = new MysqlSession () 
//注意:包含此程序前要打开数据库,主程序退出前不能关闭数据库,否则会出错。

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
967 个函式
Oct 09 PHP
PHP个人网站架设连环讲(三)
Oct 09 PHP
PHP 第三节 变量介绍
Apr 28 PHP
Codeigniter出现错误提示Error with CACHE directory的解决方案
Jun 12 PHP
php检测图片主要颜色的方法
Jul 01 PHP
PHP微信API接口类
Aug 22 PHP
PHP实现时间比较和时间差计算的方法示例
Jul 24 PHP
PHP数据库操作四:mongodb用法分析
Aug 16 PHP
PHP排序算法之希尔排序(Shell Sort)实例分析
Apr 20 PHP
PHP数组去重的更快实现方式分析
May 09 PHP
php-fpm中max_children的配置
Mar 15 PHP
php伪静态验证码不显示的解决方案
Sep 26 PHP
php判断表是否存在的方法
Jun 18 #PHP
PHP实现HTTP断点续传的方法
Jun 17 #PHP
PHP实现在线阅读PDF文件的方法
Jun 17 #PHP
php源码分析之DZX1.5字符串截断函数cutstr用法
Jun 17 #PHP
php源码分析之DZX1.5加密解密函数authcode用法
Jun 17 #PHP
php源码分析之DZX1.5随机数函数random用法
Jun 17 #PHP
php正则替换处理HTML页面的方法
Jun 17 #PHP
You might like
一个php作的文本留言本的例子(二)
2006/10/09 PHP
PHP clearstatcache()函数详解
2010/03/02 PHP
PHP图片处理之使用imagecopy函数添加图片水印实例
2014/11/19 PHP
php判断当前操作系统类型
2015/10/28 PHP
大家都应该掌握的PHP关联数组使用技巧
2015/12/25 PHP
PHP中检索字符串的方法分析【strstr与substr_count方法】
2017/02/17 PHP
javascript学习笔记(七)利用javascript来创建和存储cookie
2011/04/08 Javascript
原生的html元素选择器类似jquery选择器
2014/10/15 Javascript
JS简单操作select和dropdownlist实例
2014/11/26 Javascript
js+CSS实现弹出居中背景半透明div层的方法
2015/02/26 Javascript
js完美实现@提到好友特效(兼容各大浏览器)
2015/03/16 Javascript
jQuery实现的经典竖向伸缩菜单效果代码
2015/09/24 Javascript
深入理解NodeJS 多进程和集群
2018/10/17 NodeJs
puppeteer实现html截图的示例代码
2019/01/10 Javascript
举例简单讲解Python中的数据存储模块shelve的用法
2016/03/03 Python
Python 多线程的实例详解
2017/09/07 Python
python九九乘法表的实例
2017/09/26 Python
django rest framework之请求与响应(详解)
2017/11/06 Python
python模块常用用法实例详解
2019/10/17 Python
python各层级目录下import方法代码实例
2020/01/20 Python
从0到1使用python开发一个半自动答题小程序的实现
2020/05/12 Python
html5新增的定时器requestAnimationFrame实现进度条功能
2018/12/13 HTML / CSS
canvas简易绘图的实现(海绵宝宝篇)
2018/07/04 HTML / CSS
英国舒适型鞋履品牌:FitFlop
2017/05/17 全球购物
几道数据库的概念性面试题
2014/05/30 面试题
《美丽的彩虹》教学反思
2014/02/25 职场文书
《凡卡》教学反思
2014/04/09 职场文书
表彰大会策划方案
2014/05/13 职场文书
少先队活动总结
2014/08/29 职场文书
超市店庆活动方案
2014/08/31 职场文书
副总经理岗位职责范本
2015/04/08 职场文书
幼儿园小班班务总结
2015/08/03 职场文书
运动会跳远广播稿
2015/08/19 职场文书
MySQL学习总结-基础架构概述
2021/04/05 MySQL
python实现大文本文件分割成多个小文件
2021/04/20 Python
Vue.js中v-bind指令的用法介绍
2022/03/13 Vue.js