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
一个高ai的分页函数和一个url函数
Oct 09 PHP
php简单静态页生成过程
Mar 27 PHP
PHP 调试工具Debug Tools
Apr 30 PHP
php开发留言板的CRUD(增,删,改,查)操作
Apr 19 PHP
php获取bing每日壁纸示例分享
Feb 25 PHP
PHP实现HTML生成PDF文件的方法
Nov 07 PHP
thinkphp框架下实现登录、注册、找回密码功能
Apr 06 PHP
php nginx 实时输出的简单实现方法
Jan 21 PHP
PHP递归遍历文件夹去除注释并压缩php源代码的方法示例
May 23 PHP
ThinkPHP框架下微信支付功能总结踩坑笔记
Apr 10 PHP
PHP面向对象程序设计__tostring()和__invoke()用法分析
Jun 12 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
多数据表共用一个页的新闻发布
2006/10/09 PHP
php excel reader读取excel内容存入数据库实现代码
2012/12/06 PHP
php车辆违章查询数据示例
2016/10/14 PHP
PHP 的Opcache加速的使用方法
2017/12/29 PHP
封装的jquery翻页滚动(示例代码)
2013/11/18 Javascript
javascript实现左右控制无缝滚动
2014/12/31 Javascript
javascript实现连续赋值
2015/08/10 Javascript
基于zepto的移动端轻量级日期插件--date_picker
2016/03/04 Javascript
全面理解闭包机制
2016/07/11 Javascript
微信小程序 数据访问实例详解
2016/10/08 Javascript
JQuery实现定时刷新功能代码
2017/05/09 jQuery
Angular中ng-options下拉数据默认值的设定方法
2017/06/21 Javascript
原生javascript实现文件异步上传的实例讲解
2017/10/26 Javascript
解决vue页面DOM操作不生效的问题
2018/03/17 Javascript
BootStrap table实现表格行拖拽效果
2018/12/01 Javascript
vue-cli3+typescript新建一个项目的思路分析
2019/08/06 Javascript
Angular封装表单控件及思想总结
2019/12/11 Javascript
[03:48]2014DOTA2 TI专访71DK夺冠不靠小组赛高排名
2014/07/11 DOTA
Python实现对文件进行单词划分并去重排序操作示例
2018/07/10 Python
详解Python 定时框架 Apscheduler原理及安装过程
2019/06/14 Python
python模拟斗地主发牌
2020/04/22 Python
Python ellipsis 的用法详解
2020/11/20 Python
乌克兰香水和化妆品网站:Notino.ua
2018/03/26 全球购物
加拿大品牌鞋包连锁店:Little Burgundy
2021/02/28 全球购物
Laravel中Kafka的使用详解
2021/03/24 PHP
会计电算化专业应届大学生求职信
2013/10/22 职场文书
银行演讲稿范文
2014/01/03 职场文书
开办大学饮食联盟创业计划书
2014/01/29 职场文书
关于诚信的活动方案
2014/08/18 职场文书
公务员学习习总书记“三严三实”思想汇报
2014/09/19 职场文书
自主招生学校推荐信
2014/09/26 职场文书
先进基层党组织材料
2014/12/25 职场文书
导游词开场白
2015/01/31 职场文书
陕西导游词
2015/02/04 职场文书
基层党建工作简报
2015/07/21 职场文书
Java线程的6种状态与生命周期
2022/05/11 Java/Android