ThinkPHP5.2:路由的調整與改進

爱喝马黛茶的安东尼
發布: 2019-12-16 15:10:24
轉載
2359 人瀏覽過

ThinkPHP5.2:路由的調整與改進

ThinkPHP5.2的路由部分,也和其它元件一樣,做了精簡和優化,主要包括如下方面:

取消路由定義的返回數組形式

因為不利於路由快取生成,路由定義檔取消了返回數組的方式定義路由,必須採用路由方法註冊路由。

例如:

return [ 'hello/:name' => 'index/hello', ];
登入後複製

必須改成:

Route::get('hello/:name', 'index/hello');
登入後複製

多應用程式的路由定義檔位置

單應用模式下,路由定義檔和之前一樣就在route目錄下面,如果你的專案是採用了多應用的話,每個應用的路由定義和匹配都是獨立的,也沒有模組的概念,路由定義檔的位置應該是在route/應用子目錄下面,例如:

route/index/route.php // index应用的路由定义文件 route/index/web.php // index应用的第二个路由定义文件 route/admin/route.php // admin应用的路由定义文件
登入後複製

預設的URL規則變成了

http://域名/入口文件(或者应用名)/控制器名/操作名
登入後複製

應用的路由規則其實是定義的入口檔案(或應用程式名稱)後面的URL部分,不包含應用程式。

自動多重應用

最新的5.2版本可以支援在同一個入口檔案中存取多個不同的應用程式(之前必須每個應用程式新增一個對應的入口文件)。

例如在index.php入口檔案中使用:

(new App())->autoMulti()->run()->send();
登入後複製

就可以不必建立入口檔案自動透過URL存取多個應用程式

http://serverName/index.php/admin
登入後複製

如果你的預設應用程式不是index (預設為入口檔案名稱),那麼可以透過name方法指定預設應用。

(new App())->autoMulti() ->name('admin') ->run() ->send();
登入後複製

支援應用程式名的別名映射,例如:

(new App())->autoMulti([ 'think' => 'admin', // 把admin应用映射为think ])->run()->send();
登入後複製

如果需要對某個應用程式進行自定義,可以使用

(new App())->autoMulti([ 'admin' => function($app) { $app->debug(true)->useClassSuffix(); } ])->run()->send();
登入後複製

取消別名路由

因為使用場景有限且效能開銷問題,取消原來的別名路由功能,建議使用資源路由或單獨的路由替代。

取消快捷路由

因為使用場景有限且不太符合規範,取消了原先的控制器快速路由功能。

取消空控制器和空白操作

原來的空控制器和空白操作功能已經取消,請使用MISS路由功能替代,而且可以支援給不同的路由分組設定MISS路由。同時廢棄empty_controller配置。

取消控制器自動搜尋

由於效能原因,取消了路由的多層控制器自動搜尋功能,請在路由規則定義中明確指定要路由的多級控制器。

路由功能獨立設計

路由功能不再固定執行,而且設計成為AppInit事件的回應監聽,並且可以在專案的事件定義裡面配置,系統默認的定義配置如下:

return [ 'bind' => [ ], 'listen' => [ 'AppInit' => [ 'think\listener\LoadLangPack', 'think\listener\RouteCheck', ], 'AppBegin' => [ 'think\listener\CheckRequestCache', ], 'ActionBegin' => [], 'AppEnd' => [], 'LogLevel' => [], 'LogWrite' => [], 'ResponseSend' => [], 'ResponseEnd' => [], ], 'subscribe' => [ ], ];
登入後複製

在AppInit事件中會執行think\listener\RouteCheck類,如果你的應用程式完全不需要使用任何的路由功能,可以在設定檔中取消定義即可,系統會執行預設的URL調度(也即是控制器/操作)。

取消註冊方法的option和pattern參數

取消路由註冊方法(包括rule/get/post/put/delete/patch/miss/group等方法)的option和pattern參數,全部改成方法呼叫形式,例如原來的:

Route::get('hello/:name', 'index/hello', [ 'ext' => 'html'], [ 'name' => '\w+']);
登入後複製

需要改成

Route::get('hello/:name', 'index/hello') ->ext('html') ->pattern([ 'name' => '\w+']);
登入後複製

路由分組定義不再支援陣列

#因為不利於分組的巢狀功能,路由分組定義不再支援數組,只能使用閉包方式定義,例如:

Route::group('blog', [ ':id' => 'Blog/read', ':name' => 'Blog/read', ])->ext('html')->pattern(['id' => '\d+']);
登入後複製

必須改成

Route::group('blog', function() { Route::get(':id', 'Blog/read'); Route::get(':name', 'Blog/read'); })->ext('html')->pattern(['id' => '\d+']);
登入後複製

如果你需要註冊一個虛擬的路由分組,可以直接在第一個參數使用閉包

Route::group(function() { Route::get('blog/:id', 'Blog/read'); Route::get('user/:name', 'User/read'); })->ext('html')->pattern(['id' => '\d+']);
登入後複製

取消了url_controller_layer配置

改為在入口文件中使用controllerLayer方法設置。

(new App())->controllerLayer('Action') ->run() ->send();
登入後複製

取消class_suffix設定

改為在入口檔案中使用useClassSuffix方法設定。

(new App())->useClassSuffix(true) ->run() ->send();
登入後複製

同時取消controller_suffix和class_suffix配置參數。

取消mergeExtraVars方法和對應參數

改為在路由規則中明確指定變數規則。

header方法參數類型調整

由於強型別約束的原因,header方法改為只支援陣列參數傳入。

使用強型別參數

由於全面啟用強型別參數,並且使用嚴格模式,所以一定要注意參數的型別。

眾多ThinkPHP入門教學,盡在PHP中文網,歡迎線上學習!

本文轉自:https://blog.thinkphp.cn/916515

以上是ThinkPHP5.2:路由的調整與改進的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:thinkphp.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!