溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在ThinkPHP中對session進行操作

發(fā)布時間:2020-12-17 15:09:30 來源:億速云 閱讀:132 作者:Leah 欄目:開發(fā)技術

如何在ThinkPHP中對session進行操作?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

ThinkPHP操作session官方的說明文檔如下:

start 啟動session
pause 暫停session
clear 清除session
destroy 銷毀session
get 獲取session值
getLocal 獲取私有session值
set 設置session值
setLocal 設置私有session值
name 獲取或者設置session_name
is_set 是否設置session值
is_setLocal 是否設置私有session值
id 獲取或者設置session_id
path 獲取或者設置session_save_path
setExpire 設置session過期時 間
setCookieDomain 設置有效域名
setCallback 設置Session 對象反序列化時候的回調(diào)函數(shù)

最常用的操作方法示例代碼如下:

// 檢測Session變量是否存在
Session::is_set('name');
// 給Session變 量賦值
Session::set('name','value');
// 獲取Session變量
Session::get('name');

和Session相關的配置參數(shù)代碼如下:

'SESSION_NAME'=>'ThinkID',        // 默認Session_name
'SESSION_PATH'=>'',            // 采用默認的Session save path
'SESSION_TYPE'=>'File',            // 默認Session類型 支持 DB 和 File 
'SESSION_EXPIRE'=>'300000',        // 默認Session有效期
'SESSION_TABLE'=>'think_session',    // 數(shù)據(jù)庫Session方式表名
'SESSION_CALLBACK'=>'',            // 反序列化對象的回調(diào)方法

其中SESSION_NAME 參數(shù)需要注意,如果需要在不同的項目之間不共享傳遞Session的值,請設置不同的值,否則請保留相同的默認值。
如果設置了相同的SESSION_NAME的值,但是又希望創(chuàng)建基于項目的私有Session空間,應該怎么處理呢?ThinkPHP還支持以項目為 Session空間的私有Session操作,以之前的常用操作為例,我們更改如下:

// 檢測Session變量是否存在(當前項目有效)
Session::is_setLocal('name');
// 給Session變 量賦值(當前項目有效)
Session::setLocal('name','value');
// 獲取Session變量(當前 項目有效)
Session::getLocal('name');

這樣,和全局的Session操作就不會沖突,可以用于一些特殊情況的需要。
ThinkPHP支持數(shù)據(jù)庫方式的Session操作,設置SESSION_TYPE的值為DB就可以了,如果使用數(shù)據(jù)庫方式,還要確保設置好SESSION_TABLE的值,并且導入下面的DDL到你的 數(shù)據(jù)庫(以MySQL為例子):

CREATE TABLE `think_session` (
`id` int(11) unsigned NOT NULL auto_increment,
`session_id` varchar(255) NOT NULL,
`session_expires` int(11) NOT NULL,
`session_data` blob,
PRIMARY KEY(`id`)
)

注意,Db Session方式的數(shù)據(jù)庫連接會采用項目的數(shù)據(jù)庫配置信息進行連接。除了數(shù)據(jù)庫方式外,還可以增加其它方式的Session保存機制,例如內(nèi)存方式、 Memcache方式等,我們只要增加相應的過濾器就行了,使用session_set_save_handler 方法,具體的方法定義參考Think.Util.Filter下面的FilterSessionDb.class.php 文件的實現(xiàn)。
 
制作了一個簡單的登陸判斷
登陸檢測之后賦予Session值,使Session的值為非空即為假的false

$_SESSION[C('USER_AUTH_KEY')] = $logInFind['id'] ;

其中 [C('USER_AUTH_KEY')]為ThinkPHP的內(nèi)置方法和函數(shù)類。在未配置config.php文件時默認為空
把$logInFind['id'] 取出的帳號值賦予它,默認為關閉頁面Session就自動刪除消失!
其它頁面使用下面格式判斷

if(!isset($_SESSION[C('USER_AUTH_KEY')])) { //isset 是檢測變量是否賦值!
   $this->redirect('Login','Login'); //轉(zhuǎn)到注冊頁面
}

看完上述內(nèi)容,你們掌握如何在ThinkPHP中對session進行操作的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI