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 相关文章推荐
PHP编程之高级技巧——利用Mysql函数
Oct 09 PHP
改变Apache端口等配置修改方法
Jun 05 PHP
php操作excel文件 基于phpexcel
Jul 02 PHP
深入file_get_contents函数抓取内容失败的原因分析
Jun 25 PHP
php登陆页的密码处理方式分享
Oct 14 PHP
PHP使用缓存即时输出内容(output buffering)的方法
Aug 03 PHP
phpStudy访问速度慢和启动失败的解决办法
Nov 19 PHP
thinkPHP使用post方式查询时分页失效的解决方法
Dec 09 PHP
PHP中的随机性 你觉得自己幸运吗?
Jan 22 PHP
PHP实现阿里大鱼短信验证的实例代码
Jul 10 PHP
PHP读取并输出XML文件数据的简单实现方法
Dec 22 PHP
一次因composer错误使用引发的问题与解决
Mar 06 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安装为Apache DSO
2006/10/09 PHP
PHP4实际应用经验篇(7)
2006/10/09 PHP
php 表单验证实现代码
2009/03/10 PHP
php 字符串函数收集
2010/03/29 PHP
php5.3中连接sqlserver2000的两种方法(com与ODBC)
2012/12/29 PHP
php提示Warning:mysql_fetch_array() expects的解决方法
2014/12/16 PHP
Symfony2创建页面实例详解
2016/03/18 PHP
php实现批量上传数据到数据库(.csv格式)的案例
2017/06/18 PHP
把JS与CSS写在同一个文件里的书写方法
2007/06/02 Javascript
JavaScript子窗口ModalDialog中操作父窗口对像
2012/12/11 Javascript
node.js中的fs.fchmodSync方法使用说明
2014/12/16 Javascript
浅谈重写window对象的方法
2014/12/29 Javascript
JavaScript数组Array对象增加和删除元素方法总结
2015/01/20 Javascript
解决Jquery向页面append新元素之后事件的绑定问题
2015/03/16 Javascript
jQuery实现根据类型自动显示和隐藏表单
2015/03/18 Javascript
javascript如何实现360度全景照片问题汇总
2016/04/04 Javascript
node.js cookie-parser 中间件介绍
2016/06/06 Javascript
scroll事件实现监控滚动条并分页显示(zepto.js)
2016/12/18 Javascript
node.js入门学习之url模块
2017/02/25 Javascript
Jquery获取radio选中的值
2017/05/05 jQuery
webpack下实现动态引入文件方法
2018/02/22 Javascript
原生js调用json方法总结
2018/02/22 Javascript
关于微信小程序bug记录与解决方法
2018/08/15 Javascript
对vue中v-if的常见使用方法详解
2018/09/28 Javascript
layer ui 导入文件之前传入数据的实例
2019/09/23 Javascript
Javascript如何实现扩充基本类型
2020/08/26 Javascript
python实现从字典中删除元素的方法
2015/05/04 Python
python中循环语句while用法实例
2015/05/16 Python
Django中使用celery完成异步任务的示例代码
2018/01/23 Python
Tkinter中复选菜单是否被选中的判断与设置方式
2020/03/04 Python
python异常处理之try finally不报错的原因
2020/05/18 Python
python如何进入交互模式
2020/07/06 Python
纪伊国屋新加坡网上书店:Kinokuniya新加坡
2017/12/29 全球购物
ddl,dml和dcl的含义
2016/05/08 面试题
能否解释一下XSS cookie盗窃是什么意思
2012/06/02 面试题
小学清明节活动总结
2014/07/04 职场文书