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


Posted in PHP onJune 26, 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下保存远程图片到本地的办法
Aug 08 PHP
Apache服务器无法使用的解决方法
May 08 PHP
浅析php插件 HTMLPurifier HTML解析器
Jul 01 PHP
PHP自带函数给数字或字符串自动补齐位数
Jul 29 PHP
PHP实现在线阅读PDF文件的方法
Jun 17 PHP
Laravel Memcached缓存驱动的配置与应用方法分析
Oct 08 PHP
PHP读取CSV大文件导入数据库的实例
Jul 24 PHP
PHP实现的链式队列结构示例
Sep 15 PHP
利用PHP获取汉字首字母并且分组排序详解
Oct 22 PHP
php7函数,声明,返回值等新特性介绍
May 25 PHP
php微信开发之音乐回复功能
Jun 14 PHP
Thinkphp5框架简单实现钩子(Hook)行为的方法示例
Sep 03 PHP
Linux操作系统安装LAMP环境
Jun 26 #PHP
PHP中Session可能会引起并发问题
Jun 26 #PHP
WAMP环境中扩展oracle函数库(oci)
Jun 26 #PHP
PHP获取当前相对于域名目录的方法
Jun 26 #PHP
php通过获取头信息判断图片类型的方法
Jun 26 #PHP
以文件形式缓存php变量的方法
Jun 26 #PHP
PHP批量去除BOM头代码分享
Jun 26 #PHP
You might like
PHP中通过ADO调用Access数据库的方法测试不通过
2006/12/31 PHP
Discuz 5.0 中读取纯真IP数据库函数分析
2007/03/16 PHP
什么是MVC,好东西啊
2007/05/03 PHP
PHP目录函数实现创建、读取目录教程实例
2011/01/13 PHP
php上传图片并压缩的实现方法
2015/12/22 PHP
CL vs ForZe BO5 第三场 2.13
2021/03/10 DOTA
js判断FCKeditor内容是否为空的两种形式
2013/05/14 Javascript
js实现class样式的修改、添加及删除的方法
2015/01/20 Javascript
深入了解JavaScript中的Symbol的使用方法
2015/07/28 Javascript
javascript移动开发中touch触摸事件详解
2016/03/18 Javascript
滚动条的监听与内容随着滚动条动态加载的实现
2017/02/08 Javascript
详解js访问对象的属性和方法
2018/10/25 Javascript
利用Vue实现一个markdown编辑器实例代码
2019/05/19 Javascript
layer.open 子页面弹出层向父页面传输数据的例子
2019/09/26 Javascript
浅析JavaScript 函数防抖和节流
2020/07/13 Javascript
python获得文件创建时间和修改时间的方法
2015/06/30 Python
Python语法快速入门指南
2015/10/12 Python
浅谈python实现Google翻译PDF,解决换行的问题
2018/11/28 Python
Python通用循环的构造方法实例分析
2018/12/19 Python
Python基础学习之时间转换函数用法详解
2019/06/18 Python
Tensorflow 多线程与多进程数据加载实例
2020/02/05 Python
python实现批处理文件
2020/07/28 Python
Python Matplotlib绘图基础知识代码解析
2020/08/31 Python
html5中canvas图表实现柱状图的示例
2017/11/13 HTML / CSS
android面试问题与答案
2016/12/27 面试题
函授自我鉴定
2013/11/06 职场文书
幼教简历自我评价
2014/01/28 职场文书
网络工程师职业规划
2014/02/10 职场文书
我心目中的好老师活动方案
2014/08/19 职场文书
感恩教育主题班会
2015/08/12 职场文书
《梅花魂》教学反思
2016/02/18 职场文书
《中国古代诗歌散文欣赏》高中语文教材
2019/08/20 职场文书
python 中的jieba分词库
2021/11/23 Python
python井字棋游戏实现人机对战
2022/04/28 Python
MySQL中EXPLAIN语句及用法
2022/05/20 MySQL
SpringBoot详解整合Redis缓存方法
2022/07/15 Java/Android