検索
ホームページphp教程PHP源码php使用MySQL保存session会话

php使用MySQL保存session会话

May 25, 2016 pm 05:14 PM
mysqlphpsessionセッション使用保存

在很多大的系统中一般都有这个功能,但是要分离出来分析,网上的资料也不太多 这里我整理了一篇发出来与大家分享

使用MySQL保存session会话较files有很多优点:
1) 有利于分布式系统,files只能保存在一台机器上
2) 有利于大访问量的系统,使用files时每个session保存在一个文件中,目录会超级大,查找session文件会比较困难。

php代码

//////使用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 &#39;".$data_name."&#39;";    // 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 &#39;&#39;, 
`SessionArray` blob NOT NULL, 
`SessionExpTime` int(20) unsigned NOT NULL default &#39;0&#39;, 
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(&#39;user&#39;);
   session_set_save_handler( 
    array(&$this, &#39;sess_open&#39;), 
    array(&$this, &#39;sess_close&#39;), 
    array(&$this, &#39;sess_read&#39;), 
    array(&$this, &#39;sess_write&#39;), 
    array(&$this, &#39;sess_destroy&#39;), 
    array(&$this, &#39;sess_gc&#39;) 
   );
 
   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&#39;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 = &#39;".$SessionKey."&#39; 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 (&#39;".$SessionKey."&#39;,&#39;".$SessionExpTime."&#39;,&#39;".$SessionArray."&#39;)"; 
    $Result = mysql_query($Query, $this->DB_SELECT_DB); 
    if (!$Result){ 
           $Query = "UPDATE sessions SET SessionExpTime = &#39;".$SessionExpTime."&#39;, SessionArray = &#39;".$SessionArray."&#39; WHERE SessionKey = &#39;".$SessionKey."&#39; AND   SessionExpTime > " . time(); 
           $Result = mysql_query($Query, $this->DB_SELECT_DB); 
    }    
    return $Result; 
} 
     
function sess_destroy($SessionKey) { 
   $Query = "DELETE FROM sessions WHERE SessionKey = &#39;".$SessionKey."&#39;"; 
   $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 () 
//注意:包含此程序前要打开数据库,主程序退出前不能关闭数据库,否则会出错。
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません