Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Erläuterung der Methode zum Speichern von PHPSession in Datenbank/Redis

Detaillierte Erläuterung der Methode zum Speichern von PHPSession in Datenbank/Redis

墨辰丷
墨辰丷Original
2018-05-23 09:36:261678Durchsuche

In diesem Artikel wird hauptsächlich die Methode zur Implementierung von Sitzungsspeicher/Speicher in Redis in PHP vorgestellt. Der Herausgeber findet sie recht gut, daher werde ich sie jetzt mit Ihnen teilen und als Referenz verwenden. Folgen wir dem Editor und werfen wir einen Blick darauf.

Es ist nicht angebracht, die Standardsitzung für Websites mit hohem Datenverkehr zu verwenden. Wir können sie in der Datenbank speichern oder die Redis KEY-VALUE-Datenspeicherlösung verwenden

Erstellen Sie zunächst eine neue Sitzungstabelle

CREATE TABLE `sessions` (
 `sid` char(40) NOT NULL,
 `updatetime` int(20) NOT NULL,
 `data` varchar(200) NOT NULL,
 UNIQUE KEY `sid` (`sid`) USING HASH
) ENGINE=MEMORY DEFAULT CHARSET=utf8;

Mysqls Speicher-Engine verwendet Speichertabellen, alle Daten werden im Speicher gespeichert und die Betriebsgeschwindigkeit beträgt schnell

<?php
//引入数据库文件
include "db.php";
class MySessionHandler implements SessionHandlerInterface
{
  private $savePath;
  private $sessData;
  public $expiretime;  //设置过期时间
  public $db;  //数据库
  public function __construct($hanlder =&#39;&#39;){
     
    $this->db = Database::getInstance();  
     
    //获取数据库实力 
    ///var_dump($this->db);
     
  }
   
  public function open($savePath, $sessionName)
  {
 
    return true;
  }
 
  public function close()
  {
    return true;
  }
 
  public function read($id)
  {  
    $sql ="select * from sessions where sid =&#39;$id&#39;";
    $result = $this->db->execute($sql);
      if(!empty($result)){
         return $this->sessData = $result;
      }
  }
      //函数的参数 $id -> 当前会话ID
      //数据DATA -> 序列化之后的字符串
  public function write($id, $data)
  {
    // echo $id;
    // echo $data;
    $now = time();
    $newExp = $now+$this->expiretime;  //总时间=当前时间 + 期限时间
    $sql = "select * from sessions where sid =&#39;$id&#39;";
    $result = $this->db->getOne($sql);
    //var_dump($result);
    if($data==&#39;&#39;||isset($data)){
      $data = $this->sessData;
    }
      if($result){
      //如果存在则更新
  $sql ="update sessions set updatetime = &#39;$newExp&#39;,data =&#39;$data&#39; where sid = &#39;$id&#39;";
        //echo $sql;
          $update_data =$this->db->execute($sql);
          if($update_data){
            return true;
          }
         
      }else{
      //不存在则生成生成
  $sql = "insert into sessions(sid,updatetime,data) values(&#39;$id&#39;,&#39;$now&#39;,&#39;$data&#39;)";
    $insert_data = $this->db->execute($sql);
    if($insert_data){
    return true;
        }
      }
      return false;
  }
 
  public function destroy($id)
  {    //销毁
    $sql = "delete from sessions where sid="."$id";
    $destory = $this->db->execute($sql);
    if($destory){
       return true;
    }else{
      return false;
    }
  }
 
  public function gc($sessMaxLifeTime)
  {
   $t = time();
  $sql ="delete from sessions where $t - &#39;updatetime&#39;>${sessMaxLifeTime}";
    $data = $this->db->execute($this->tosql);
    if($data){
      return true;
    }else{
      return false;
      }
    return true;
  }
}

Instantiierung

Im PHP-Handbuch gibt es hier zwei Methoden

1. Objekt, das die SessionHandlerInterface-Schnittstelle implementiert , seit PHP5.4 Sie können

2 verwenden, verwenden Sie direkt session_set_save_handler

//判断PHP版本
 if(version_compare(PHP_VERSION,5.4)==1){
       
   session_set_save_handler($handler, true);
  session_start();
  }else{  
    ini_set(&#39;session.use_trans_sid&#39;,0);
    ini_set(&#39;session.use_cookies&#39;,1);
    ini_set(&#39;session.cookie_path&#39;,&#39;/&#39;);
      ini_set(&#39;session.save_handler&#39;,&#39;user&#39;);
      session_module_name(&#39;user&#39;);
      session_set_save_handler(array($session,"open"),array($session,"close"),array($session,"read"),array($session,"write"),array($session,"destory"),array($session,"gc"));
      session_start();   
     }
$_SESSION[&#39;QQ&#39;]="QQ";
echo $_SESSION[&#39;QQ&#39;];

Datenbankcode db.php

<?php 
class Database{
     static $instance;
    static $db;
  static function getInstance(){   
    if(self::$instance){
      return self::$instance;
    }else{
      return new Database();  
    }
  }
  public function __construct(){
    self::$db = new PDO(&#39;mysql:host=localhost;dbname=session&#39;, &#39;root&#39;,&#39;&#39;);
  }
 
    public function getOne($sql){
      $rs =self::$db->query($sql);
      @$rs->setFetchMode(PDO::FETCH_ASSOC);//返回关联数组
      $result = $rs -> fetch();
      return $result;
    }
    public function execute($sql){
       
       
        $rs = self::$db->exec($sql);
        return $rs;
         
    } 
   
 
}
 
 
//$data = Database::getInstance();
//var_dump($data);

Verwenden Sie REDIS zum Speichern von SESSION

<?php
class SessionManager{
  private $redis;
  private $sessionSavePath;
  private $sessionName;
  private $sessionExpireTime = 30;
  public function __construct(){
    $this->redis = new Redis();
    $this->redis->connect(&#39;127.0.0.1&#39;,6379);  //连接redis
    $retval = session_set_save_handler(
      array($this,"open"),
      array($this,"close"),
      array($this,"read"),
      array($this,"write"),
      array($this,"destory"),
      array($this,"gc")
    );
      session_start();
  }
   
    public function open($path,$name){
      return true;
    }
    public function close(){
      return true;
    }
    public function read($id){
      $value = $this->redis->get($id);
      if($value){
        return $value;
      }else{
        return "";
      }
    }
    public function write($id,$data){
      if($this->redis->set($id,$data)){
        $this->redis->expire($id,$this->sessionExpireTime); 
         //设置过期时间
        return true;
      }
      return false;
    }
    public function destory($id){
      if($this->redis->delete($id)){
        return true;
      }
      return false;
    }
    public function gc($maxlifetime){
      return true;
    }
    //析构函数
    public function __destruct(){
      session_write_close();
    }
     
}
 
 
$re = new SessionManager();
$_SESSION[&#39;name&#39;] = "qq";
echo $_SESSION[&#39;name&#39;];

Verwandte Empfehlungen:

PHP-Studie Notizen objektorientiert

PHP-Reflexionsklasse ReflectionClass-Verwendungsanalyse_php-Fähigkeiten

PHPGrundlegende Syntax Wissenspunkte für den Einstieg in die Programmierung Zusammenfassung_php-Grundlagen

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Methode zum Speichern von PHPSession in Datenbank/Redis. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn