ThinkPHP6.0:Session和Cookie機制的變化

?

ThinkPHP6.0:Session和Cookie機制的變化

最新的6.0版本對框架的Session和Cookie機制進行了重新設計,擺脫了原有設計的束縛。

Session

新的Session機制不依賴PHP內置的Session會話機制,完全獨立實現,優勢在于可以兼容任何的運行環境,而且配置參數也大為簡化。

立即學習PHP免費學習筆記(深入)”;

新版你不能再使用$_SESSION或者任何php內置的session函數操作Session,必須通過thinkSession類或者think acadeSession靜態代理類操作Session數據。

Session對于很多API接口應用來說,不是必須的,而隨著前后端分離的應用架構設計越來越多,因此6.0的Session默認是關閉的,系統把Session相關的功能設計成一個獨立的中間件,如果你需要使用Session可以單獨在應用的中間件定義文件中開啟。

默認安裝后,在app目錄下的middleware.php中間件定義文件中,對可能需要使用的系統中間件預置了注釋,你可以直接取消注釋,加上:

//?Session初始化 'thinkmiddlewareSessionInit',

該中間件的作用主要是初始化SessionId,并注入當前的請求對象。初始化的時候會自動讀取config目錄下的session.php配置。

默認使用文件的方式保存Session數據,支持使用redis、memcache以及memcached。

內置的Session驅動默認配置下,都是支持跨應用讀取Session數據的。如果你需要區分不同的應用,保持各個應用的Session數據獨立,可以在應用的session配置文件中設置prefix參數,例如:

'prefix'?=>?'admin',

并且為了防止Session數據過多,文件方式寫入Session數據的時候支持垃圾回收機制。可以配置gc_divisor和gc_maxlifetime兩個參數來設置GC回收。

Session數據會在當前請求結束后,自動寫入,一般只會寫入一次。Session數據寫入之前會首先進行序列化,默認的序列化方法是serialize/unserialize,你可以在session配置文件中設置serialize參數(數組)來改變默認的序列化機制,例如:

'serialize'?=>?['json_encode',?'json_decode'],

Session類本身的用法和之前版本基本一致,增加了push方法用于追加一個session數組。

Cookie

Cookie的存取機制是分開設計的,讀取操作是通過$_COOKIE讀取,寫入則通過可擴展的方式滿足不同運行環境的Cookie寫入要求。Cookie數據的寫入操作也是在當前請求發送響應數據之前統一寫入。

但在實際使用中,Cookie的用法和之前類似,區別在于不再支持前綴配置和清空操作。

PHP中文網,大量的免費ThinkPHP入門教程,歡迎在線學習!

php中文網學習專題ThinkPHP入門教程 (包含圖文、視頻、案例)

本文轉自:ThinkPHP入門教程

? 版權聲明
THE END
喜歡就支持一下吧
點贊10 分享