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 相关文章推荐
一个程序下载的管理程序(二)
Oct 09 PHP
PHP合并两个数组的两种方式的异同
Sep 14 PHP
解析dedeCMS验证码的实现代码
Jun 07 PHP
解析如何在PHP下载文件名中解决乱码的问题
Jun 20 PHP
mac环境中使用brew安装php5.5.15
Aug 18 PHP
PHP中使用Session配合Javascript实现文件上传进度条功能
Oct 15 PHP
详解PHP对象的串行化与反串行化
Jan 24 PHP
php 判断过去离现在几年的函数(实例代码)
Nov 15 PHP
PHP绕过open_basedir限制操作文件的方法
Jun 10 PHP
Yii框架数据库查询、增加、删除操作示例
Oct 14 PHP
PHP使用PDO实现mysql防注入功能详解
Dec 20 PHP
基于PHP实现短信验证码发送次数限制
Jul 11 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
MYSQL环境变量设置方法
2007/01/15 PHP
php curl post 时出现的问题解决
2014/01/30 PHP
PHP中获取时间的下一周下个月的方法
2014/03/18 PHP
destoon安全设置中需要设置可写权限的目录及文件
2014/06/21 PHP
php使用iconv中文截断问题的解决方法
2015/02/11 PHP
PHP文件缓存smarty模板应用实例分析
2016/02/26 PHP
php获取ip及网址的简单方法(必看)
2017/04/01 PHP
php对xml文件的增删改查操作实现方法分析
2017/05/19 PHP
jQuery 判断元素上是否绑定了事件
2009/10/28 Javascript
js查错流程归纳
2012/05/04 Javascript
html超链接打开窗口大小的方法
2013/03/05 Javascript
jQuery插件的写法分享
2013/06/12 Javascript
jquery选择器-根据多个属性选择示例代码
2013/10/21 Javascript
javascript学习笔记(五)原型和原型链详解
2014/10/08 Javascript
什么是 AngularJS?AngularJS简介
2014/12/06 Javascript
JavaScript删除指定子元素代码实例
2015/01/13 Javascript
jQuery+AJAX实现遮罩层登录验证界面(附源码)
2020/09/13 Javascript
jQuery实现CheckBox全选、全不选功能
2017/01/11 Javascript
JS sort方法基于数组对象属性值排序
2020/07/10 Javascript
python 基础学习第二弹 类属性和实例属性
2012/08/27 Python
python中threading超线程用法实例分析
2015/05/16 Python
Python计算三维矢量幅度的方法
2015/06/15 Python
python实现用户登陆邮件通知的方法
2015/07/09 Python
Python实现的银行系统模拟程序完整案例
2019/04/12 Python
手把手教你将Flask应用封装成Docker服务的实现
2020/08/19 Python
日本著名的平价时尚女性购物网站:Fifth
2016/08/24 全球购物
佳能法国商店:Canon法国
2019/02/14 全球购物
日常奢侈品,轻松购物:Verishop
2019/08/20 全球购物
The North Face北面荷兰官网:美国著名户外品牌
2019/10/16 全球购物
消防安全责任书范本
2014/04/15 职场文书
工程承包协议书
2014/04/22 职场文书
营销部内勤岗位职责
2014/04/30 职场文书
2014初中数学教研组工作总结
2014/12/19 职场文书
一年级数学下册复习计划
2015/01/17 职场文书
继承公证书格式
2015/01/26 职场文书
Python Socket编程详解
2021/04/25 Python