PHP實現(xiàn)Session入庫/存入redis的方法
對于大訪問量的站點使用默認的Session 并不合適,我們可以將其存入數(shù)據(jù)庫、或者使用Redis KEY-VALUE數(shù)據(jù)存儲方案
首先新建一個session表
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;
Mysql 的memory引擎采用內(nèi)存表,所有數(shù)據(jù)存儲在內(nèi)存,操作速度快
<?php //引入數(shù)據(jù)庫文件 include "db.php"; class MySessionHandler implements SessionHandlerInterface { private $savePath; private $sessData; public $expiretime; //設(shè)置過期時間 public $db; //數(shù)據(jù)庫 public function __construct($hanlder =''){ $this->db = Database::getInstance(); //獲取數(shù)據(jù)庫實力 ///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 ='$id'"; $result = $this->db->execute($sql); if(!empty($result)){ return $this->sessData = $result; } } //函數(shù)的參數(shù) $id -> 當前會話ID //數(shù)據(jù)DATA -> 序列化之后的字符串 public function write($id, $data) { // echo $id; // echo $data; $now = time(); $newExp = $now+$this->expiretime; //總時間=當前時間 + 期限時間 $sql = "select * from sessions where sid ='$id'"; $result = $this->db->getOne($sql); //var_dump($result); if($data==''||isset($data)){ $data = $this->sessData; } if($result){ //如果存在則更新 $sql ="update sessions set updatetime = '$newExp',data ='$data' where sid = '$id'"; //echo $sql; $update_data =$this->db->execute($sql); if($update_data){ return true; } }else{ //不存在則生成生成 $sql = "insert into sessions(sid,updatetime,data) values('$id','$now','$data')"; $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 - 'updatetime'>${sessMaxLifeTime}"; $data = $this->db->execute($this->tosql); if($data){ return true; }else{ return false; } return true; } }
實例化
此處 PHP 手冊可以有兩種方法
1,實現(xiàn)了SessionHandlerInterface借口的對象,自PHP5.4可以使用
2 ,直接使用 session_set_save_handler
//判斷PHP版本 if(version_compare(PHP_VERSION,5.4)==1){ session_set_save_handler($handler, true); session_start(); }else{ ini_set('session.use_trans_sid',0); ini_set('session.use_cookies',1); ini_set('session.cookie_path','/'); ini_set('session.save_handler','user'); session_module_name('user'); 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['QQ']="QQ"; echo $_SESSION['QQ'];
數(shù)據(jù)庫代碼 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('mysql:host=localhost;dbname=session', 'root',''); } public function getOne($sql){ $rs =self::$db->query($sql); @$rs->setFetchMode(PDO::FETCH_ASSOC);//返回關(guān)聯(lián)數(shù)組 $result = $rs -> fetch(); return $result; } public function execute($sql){ $rs = self::$db->exec($sql); return $rs; } } //$data = Database::getInstance(); //var_dump($data);
使用REDIS 存儲SESSION
<?php class SessionManager{ private $redis; private $sessionSavePath; private $sessionName; private $sessionExpireTime = 30; public function __construct(){ $this->redis = new Redis(); $this->redis->connect('127.0.0.1',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); //設(shè)置過期時間 return true; } return false; } public function destory($id){ if($this->redis->delete($id)){ return true; } return false; } public function gc($maxlifetime){ return true; } //析構(gòu)函數(shù) public function __destruct(){ session_write_close(); } } $re = new SessionManager(); $_SESSION['name'] = "qq"; echo $_SESSION['name'];
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用PHP備份MySQL和網(wǎng)站發(fā)送到郵箱實例代碼
這篇文章主要介紹了使用PHP備份MySQL和網(wǎng)站發(fā)送到郵箱的方法,大家參考使用吧2013-11-11Laravel中重寫資源路由自定義URL的實現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于Laravel中重寫資源路由自定義URL的實現(xiàn)方法,需要的朋友可以參考下2017-08-08php中配置文件保存修改操作 如config.php文件的讀取修改等操作
有時候我們需要用php將一些配置參數(shù)寫到文件里面,方便后期讀取使用,這里就為大家分享一下具體的實現(xiàn)代碼,需要的朋友可以參考一下2021-05-05thinkphp表單上傳文件并將文件路徑保存到數(shù)據(jù)庫中
這篇文章主要介紹了thinkphp表單上傳文件并將文件路徑保存到數(shù)據(jù)庫中的相關(guān)資料,需要的朋友可以參考下2016-07-07詳解PHP中strlen和mb_strlen函數(shù)的區(qū)別
在PHP中,strlen與mb_strlen是求字符串長度的函數(shù),但是對于一些初學者來說,如果不看手冊,也許不太清楚其中的區(qū)別2014-03-03php生成二維碼不保存服務器還有下載功能的實現(xiàn)代碼
這篇文章主要介紹了php生成二維碼不保存服務器還有下載功能的實現(xiàn)代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-08-08