ThinkPHP最新的6.0
版本原計劃於國慶左右發布,由於國慶期間本著核心精簡的原則對多應用模式做了一些調整,為了避免可能的問題還需要做更充分的測試,加上新版框架的安全審計工作仍然還在繼續,所以在計劃之外額外發布了一個RC5
積累更新版本,正式版本的發布日期推遲到10月24日。
官方本著認真和嚴謹的態度對待此次ThinkPHP
6.0
的發布工作,我們希望交付給開發者的新版是一個更好用而且架構穩定的版本,相信這是一個值得等待的框架。
下面是RC5
版本自RC4
之後的主要更新,基本上不影響之前版本的升級,並且官方完全開發手冊的內容已經同步更新。
鑒於多應用模式的複雜性和擴展性考慮,最新版本把多應用模式獨立為框架的一個全局中間件擴展。默認安裝后核心框架為單應用模式,如果需要使用多應用模式,可以安裝
composer require topthink/think-multi-app
安裝後會自動註冊一個全局中間件並優先執行,就可以自動支持多應用模式,無需做任何的配置調整。如果需要進行應用映射或者域名綁定的話,仍然設置app_map
以及domain_bind
即可。
如果你的入口文件是index.php
的話,會自動開啟自動多應用模式。如果你的入口文件是其它,例如admin.php
或者api.php
則會自動綁定admin
或者api
應用,當然,如果你在入口文件中已經使用name
方法綁定了應用,則優先。
另外,如果是自動多應用模式下,URL裡面的應用不存在,會自動處理為單應用解析,也就是說多應用和單應用是可以在新版的架構下共存。舉個例子,當我們訪問下面的URL:
http://tp.com/think
假設think
應用並不存在(也沒有定義任何的應用映射),當我們訪問上面的地址的時候會自動進行單應用解析,也就是說如果有定義全局路由(例如route/route.php
)的話
Route::get('think', function () {
return 'hello,ThinkPHP!';
});
頁面會輸出
hello,ThinkPHP!
這樣設計的初衷是為了更加方便擴展註冊全局路由,避免在開啟多應用模式的情況下註冊的全局路由失效(比如之前的驗證碼擴展只能用於單應用模式,多應用模式需要單獨註冊路由)。
如果你完全不需要單應用模式,也可以設置使用嚴格的多應用模式
'app_express' => true,
'default_app' => 'home',
當我們再次訪問
http://tp.com/think
的時候,其實是訪問默認(home
)應用的think
路由。
由於多應用擴展獨立后,中間件機制也隨之進行了一些優化和調整,現在中間件大致分為四個組,包括全局中間件、應用中間件、路由中間件和控制器中間件,每個中間件組彼此獨立按順序運行。
在app/middleware.php
文件裡面定義的中間件即為全局中間件,執行優先順序最高(相對於前置中間件而言),如果使用了多應用模式,並且在應用目錄下也定義了middleware.php
文件,即為應用中間件,執行優先順序僅次於全局中間件。
如果在路由註冊的時候定義了中間件即為路由中間件,注意,在路由中間件執行之前是獲取不到當前應用的控制器和操作名的(所以,全局中間件和應用中間件執行的過程中是無法獲取控制器和操作名的),如果你不想在路由註冊的時候定義中間件,還有一個額外的辦法,就是在路由配置文件(包括全局路由配置和應用路由配置)中定義middleware
參數,無論是否匹配路由都會執行,類似於全局路由中間件的概念。
'middleware' => [
app\middleware\Auth::class,
app\middleware\Check::class,
],
中間件的執行流程改進,think\middleware
僅僅負責中間件的管理和調度,增加think\Pipeline
類負責中間件的執行。並支持控制中間件的執行順序。中間件配置文件的格式做了一些調整,除了定義中間件別名外,增加了執行優先順序設置。
return [
// 別名或分組
'alias' => [
],
// 優先順序設置,此數組中的中間件會按照數組中的順序優先執行
'priority' => [
],
];
end
回調中間件增加end
回調,如果在中間件類中有定義end
方法,則會在請求結束后統一調用。
public function end(Response $response)
{
}
對於每個分組的中間件,會進行強制去重操作,也就是說在一個分組中的中間件只可能執行一次。
模板目錄無需再進行任何的配置,取消了view_base
配置,改為自動識別,應用目錄下的view
目錄優先,如果不存在,則會使用應用根目錄下的view
目錄。如果要單獨定義某個應用的模板目錄,則使用view_path
配置參數定義即可。
事件智能訂閱的時候不再需要事先註冊和定義事件,採用反射機制自動識別訂閱事件。
多應用模式改成擴展后,核心已經完全解耦了多應用相關的方法和屬性,所以如果你需要獲取當前的應用名,需要改成
app('http')->getName();
對於使用中間件進行許可權控制用途的,官方的建議是採用pathinfo
地址進行許可權判斷。
think-swoole
擴展更新think-swoole
擴展也在持續更新和完善,現在已經支持資料庫和緩存的連接池功能,以及RPC功能。
原來內置的頁面Trace調試工具已經更改為擴展的方式,改成安裝think-trace
擴展,如果通過composer安裝應用的話,默認會安裝topthink/think-trace
擴展,或者直接安裝。
composer require topthink/think-trace
原核心內置的
TraceDebug
中間件不再使用,請在中間件定義文件中註釋掉。
基本用法和之前保持不變,但無需額外配置,默認使用html
方式顯示,同時仍然支持瀏覽器控制台顯示,並僅在調試模式下有效。
同時增加了一個基於debugbar
的調試擴展think-debugbar
,需要單獨安裝后才能使用。
composer require topthink/think-debugbar
最後一個是關於官網的消息,為了迎接新版的發布,ThinkPHP官網這次終於要更新了。官方計劃在本月對舊版(史前)官網進行ThinkPHP6.0
的升級重構,同時改進用戶體驗和手機閱讀體驗。
[admin
]