国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

ThinkPHP關于session的操作方法匯總

2024-05-04 23:24:25
字體:
來源:轉載
供稿:網友

本文詳細講述了ThinkPHP關于session的各種操作方法,詳情如下:

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 對象反序列化時候的回調函數

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

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

和Session相關的配置參數代碼如下:

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

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

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

這樣,和全局的Session操作就不會沖突,可以用于一些特殊情況的需要。
ThinkPHP支持數據庫方式的Session操作,設置SESSION_TYPE的值為DB就可以了,如果使用數據庫方式,還要確保設置好SESSION_TABLE的值,并且導入下面的DDL到你的 數據庫(以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方式的數據庫連接會采用項目的數據庫配置信息進行連接。除了數據庫方式外,還可以增加其它方式的Session保存機制,例如內存方式、 Memcache方式等,我們只要增加相應的過濾器就行了,使用session_set_save_handler 方法,具體的方法定義參考Think.Util.Filter下面的FilterSessionDb.class.php 文件的實現。
 
制作了一個簡單的登陸判斷
登陸檢測之后賦予Session值,使Session的值為非空即為假的false

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

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 荆门市| 乌鲁木齐县| 凌源市| 邓州市| 高淳县| 吉林省| 益阳市| 洪江市| 从化市| 洪雅县| 旬邑县| 衡南县| 巴里| 天峨县| 马鞍山市| 文成县| 平顺县| 白沙| 休宁县| 米脂县| 禹州市| 津南区| 突泉县| 连城县| 合川市| 阳西县| 浦北县| 高密市| 余庆县| 永城市| 嘉善县| 如皋市| 琼中| 许昌市| 沧源| 朝阳县| 朝阳县| 阜平县| 北宁市| 辽宁省| 廊坊市|