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 相关文章推荐
elgg 获取文件图标地址的方法
Mar 20 PHP
Google Voice 短信发送接口PHP开源版(2010.5更新)
Jul 22 PHP
php addslashes 利用递归实现使用反斜线引用字符串
Aug 05 PHP
php读取目录所有文件信息dir示例
Mar 18 PHP
php curl请求信息和返回信息设置代码实例
Apr 27 PHP
php实现zip文件解压操作
Nov 03 PHP
php自定义函数转换html标签示例
Sep 29 PHP
10个值得深思的PHP面试题
Nov 14 PHP
利用PHP获取汉字首字母并且分组排序详解
Oct 22 PHP
php处理抢购类功能的高并发请求
Feb 08 PHP
浅析php如何实现爬取数据原理
Sep 27 PHP
Yii框架参数配置文件params用法实例分析
Sep 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
Zend引擎的发展 [15]
2006/10/09 PHP
PHP回调函数概念与用法实例分析
2017/11/03 PHP
PHP实现数据库的增删查改功能及完整代码
2018/04/18 PHP
php连接mysql之mysql_connect()与mysqli_connect()的区别
2020/07/19 PHP
jQuery学习5 jQuery事件模型
2010/02/07 Javascript
使用Jquery打造最佳用户体验的登录页面的实现代码
2011/07/08 Javascript
JavaScript ECMA-262-3 深入解析.第三章.this
2011/09/28 Javascript
js限制textarea每行输入字符串长度的代码
2012/10/31 Javascript
textarea不能通过maxlength属性来限制字数的解决方法
2014/09/01 Javascript
使用JavaScript刷新网页的方法
2015/06/04 Javascript
javascript获取select值的方法分析
2015/07/02 Javascript
JavaScript组合模式学习要点
2016/08/26 Javascript
js实现5秒倒计时重新发送短信功能
2017/02/05 Javascript
详解从新建vue项目到引入组件Element的方法
2017/08/29 Javascript
webpack vue项目开发环境局域网访问方法
2018/03/20 Javascript
新版vue-cli模板下本地开发环境使用node服务器跨域的方法
2018/04/03 Javascript
jQuery实现鼠标移入显示蒙版效果
2020/01/11 jQuery
Python数据结构与算法之图的广度优先与深度优先搜索算法示例
2017/12/14 Python
flask框架自定义过滤器示例【markdown文件读取和展示功能】
2019/11/08 Python
pycharm设置默认的UTF-8编码模式的方法详解
2020/06/01 Python
Python 数据分析之逐块读取文本的实现
2020/12/14 Python
猫咪家具:CatsPlay
2018/11/03 全球购物
L’Artisan Parfumeur官网:法国香水品牌
2020/08/11 全球购物
神路信息Java面试题目
2013/03/31 面试题
什么是反射
2012/03/17 面试题
Servlet如何得到服务器的信息
2015/12/22 面试题
工商管理系学生的自我评价分享
2013/11/29 职场文书
《王二小》教学反思
2014/02/27 职场文书
建筑院校毕业生求职信
2014/06/13 职场文书
单位委托书怎么写
2014/08/02 职场文书
销售竞赛活动方案
2014/08/23 职场文书
黑暗中的舞者观后感
2015/06/18 职场文书
周一早安温馨问候祝福语!
2019/07/15 职场文书
php TP5框架生成二维码链接
2021/04/01 PHP
在Spring-Boot中如何使用@Value注解注入集合类
2021/08/02 Java/Android
windows server2008 开启端口的实现方法
2022/06/25 Servers