ThinkPHP自定義Redis處理SESSION的實(shí)現(xiàn)方法
本文實(shí)例講述了ThinkPHP自定義Redis處理SESSION的實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
日常中我們都會(huì)使用到session來保存用戶登錄的信息,常用的session的保存方式有:文件保存(默認(rèn))、數(shù)據(jù)庫保存、Redis保存、memcached等。這里主要記錄一下在用ThinkPHP處理session用Redis來保存session的用法。
1.在配置項(xiàng)中定義:
'SESSION_TYPE' => 'Redis', //session保存類型 'SESSION_PREFIX' => 'sess_', //session前綴 'REDIS_HOST' => '127.0.0.1' //REDIS服務(wù)器地址 'REDIS_PORT' => 6379, //REDIS連接端口號(hào) 'SESSION_EXPIRE' => 3600, //SESSION過期時(shí)間
可以ThinkPHP/Common/functions.php文件中找到定義session的方法,大約在1179行左右讀取session驅(qū)動(dòng)的判斷。如果我們定義了配置項(xiàng)SESSION_TYPE,則會(huì)new一個(gè)Redis對(duì)象并調(diào)用會(huì)話存儲(chǔ)函數(shù)session_set_save_handler()。
2.在ThinkPHP\Library\Think\Session\Driver目錄下新建Redis.class.php文件
文件內(nèi)容如下:
<?php namespace Think\Session\Driver; class Redis { // Redis連接對(duì)象 private $redis; // Session過期時(shí)間 private $expire; /** * 打開方法 * @param type $path * @param type $name * @return type */ public function open($path, $name) { $this->expire = C('SESSION_EXPIRE') ? C('SESSION_EXPIRE') : ini_get('session.gc_maxLifetime'); $this->redis = new Redis(); return $this->redis->connect(C('REDIS_HOST'), C('REDIS_PORT')); } /** * 關(guān)閉 * @return type */ public function close() { return $this->redis->close(); } /** * 讀取 * @param string $id * @return type */ public function read($id) { $id = C('SESSION_PREFIX') . $id; $data = $this->redis->get($id); return $data ? $data : ''; } /** * 寫入 * @param string $id * @param type $data * @return type */ public function write($id, $data) { $id = C('SESSION_PREFIX') . $id; return $this->redis->set($id, $data, $this->expire); } /** * 銷毀 * @param string $id */ public function destroy($id) { $id = C('SESSION_PREFIX') . $id; $this->redis->delete($id); } /** * 垃圾回收 * @param type $maxLifeTime * @return boolean */ public function gc($maxLifeTime) { return true; } }
至此就完成了Redis對(duì)session的處理。
memcached的方法和Redis差不多一樣!
補(bǔ)充:小編在這里推薦一款本站的php格式化美化的排版工具幫助大家在以后的PHP程序設(shè)計(jì)中進(jìn)行代碼排版:
php代碼在線格式化美化工具:http://tools.jb51.net/code/phpformat
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《ThinkPHP常用方法總結(jié)》、《smarty模板入門基礎(chǔ)教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
- thinkphp6中Redis 的基本使用方法詳解
- Thinkphp6.0中間件的具體使用
- ThinkPHP6.0前置、后置中間件區(qū)別
- thinkphp6使用mysql悲觀鎖解決商品超賣問題的實(shí)現(xiàn)
- ThinkPHP6通過Ucenter實(shí)現(xiàn)注冊(cè)登錄的示例代碼
- ThinkPHP6.0如何利用自定義驗(yàn)證規(guī)則規(guī)范的實(shí)現(xiàn)登陸
- 基于thinkphp6.0的success、error實(shí)現(xiàn)方法
- 使用composer安裝使用thinkphp6.0框架問題【視頻教程】
- windows?server?2012?r2?服務(wù)器部署tp6?項(xiàng)目
- ThinkPHP5中如何使用redis
- 寶塔中ThinkPHP框架使用Redis的一系列教程
- Thinkphp6 配置并使用redis圖文詳解
相關(guān)文章
php 如何禁用eval() 函數(shù)實(shí)例詳解
在php中eval是一個(gè)函數(shù)并且不能直接禁用了,但eval函數(shù)又相當(dāng)?shù)奈kU(xiǎn)并經(jīng)常會(huì)出現(xiàn)一些問題,今天我們就一起來看看eval函數(shù)對(duì)數(shù)組的操作及php 如何禁用eval() 函數(shù),需要的朋友可以參考下2016-12-12php使用正則驗(yàn)證密碼字段的復(fù)雜強(qiáng)度原理詳細(xì)講解
密碼涉及到安全問題,所以密碼設(shè)計(jì)的復(fù)雜程序尤為重要。通常密碼由大小寫字母、數(shù)字、特殊符號(hào)組成。一般情況下前端可不做js判斷,使用ajax提交php后端程序接口,由后端判斷后返回json數(shù)據(jù),進(jìn)行用戶密碼復(fù)雜程序提示。2022-11-11php實(shí)現(xiàn)的短網(wǎng)址算法分享
這篇文章主要介紹了php實(shí)現(xiàn)的短網(wǎng)址算法,理論上支持1,073,741,824個(gè)短網(wǎng)址,個(gè)人使用足夠了,需要的朋友可以參考下2014-06-06PHP中使用strpos函數(shù)實(shí)現(xiàn)屏蔽敏感關(guān)鍵字功能
這篇文章主要介紹了PHP中使用strpos函數(shù)實(shí)現(xiàn)屏蔽敏感關(guān)鍵字功能,本文用在發(fā)布文章保存到數(shù)據(jù)庫時(shí)前攔截敏感關(guān)鍵,需要的朋友可以參考下2014-08-08