TP5路由知識簡單個人彙總

一、路由的模式

普通模式(默認pathinfo,不解析路由)

‘url_route_on’ => false

混合模式(pathinfo+解析路由)

‘url_route_on’ => true,
‘url_route_must’=> false,

強制模式(必須路由)

‘url_route_on’ => true,
‘url_route_must’ => true,

二、動態註冊路由

1、動態註冊路由

Route::rule(‘路由表達式’,‘路由地址’,‘請求類型’,‘路由參數(數組)’,‘變量規則(數組)’);

實例
return [
Route::rule('demo/:name/[:sex]', 'index/Index/demo', 'GET', ['ext' => 'html'], ['name' => '\w+', 'age' => '\w{1,2}']),
]

路由表達式:demo/:name/[:sex](”[]“爲可選)
路由地址:/index/Index/demo
請求類型:get|post| 等
路由參數:[‘ext’=>‘html’](後綴檢測)等等
變量規則:[‘sex’=>‘0|1’](只能爲0和1)等等,正則表達式

//根路徑下使用閉包
Route::get('/', function () {
	echo '我是demo3,臨時維護,謝謝支持!';
}),

//301重定向
// 	Route::get('demo4', 'http://www.baidu.com'),
2、數組方式動態註冊路由(簡潔)
return [
//pattern全局變量
'__pattern__' => [
	'name' => '\w+',
	...
],

'demo2' => 'admin/Index/demo2',
'demo3/:name/:age' => ['admin/Index/demo3', ['method' => 'get', 'ext' => 'asp'], ['age' => '\d+']],
'demo4/:name/:money' => ['admin/Index/demo4', ['method' => 'get', 'ext' => 'asp'], ['money' => '\d+']],
'demo5/:name' => ['admin/Index/demo5', ['method' => 'get', 'ext' => 'php'], []],
];

三、路由分組

個人:同一個路由定義(demo),根據URL傳遞參數的值的不同,而匹配不同的變量規則,從而進入不同的路由規則。例如以下

①逐條

'demo/:num' => ['admin/Index/demo1', ['method' => 'get'], ['num' => '\d{2,4}']],
'demo/:str' => ['admin/Index/demo2', ['method' => 'get'], ['str' => '[a-zA-Z]+']],
'demo/:bool' => ['admin/Index/demo3', ['method' => 'get'], ['bool' => '0|1']],

②合併

'[demo]' => [
	':num' => ['admin/Index/demo1', ['method' => 'get'], ['num' => '\d{2,4}']],
	':str' => ['admin/Index/demo2', ['method' => 'get'], ['str' => '[a-zA-Z]+']],
	':bool' => ['admin/Index/demo3', ['method' => 'get'], ['bool' => '0|1']],
],

③使用group分組註冊

//Route::group(‘路由表達式’,‘對路由的定義’);
think\Route::group('demo', [
	':num' => ['admin/Index/demo1', ['method' => 'get'], ['num' => '\d{2,4}']],
	':str' => ['admin/Index/demo2', ['method' => 'get'], ['str' => '[a-zA-Z]+']],
	':bool' => ['admin/Index/demo3', ['method' => 'get'], ['bool' => '0|1']],
]);

④從③提取共同的部分——簡化

think\Route::group('demo', [
	':num' => 'demo1',
	':str' => 'demo2',
	':bool' => 'demo3',
], ['method' => 'get', 'prefix' => 'admin/Index/'], ['num' => '\d{2,4}', 'str' => '[a-zA-Z]+', 'bool' => '0|1']);

⑤路由分組閉包嵌套

個人:和第④的路由功能基本一致,如果不是什麼特別需求或者習慣使用閉包,就少用或不用吧

Route::group(['method'=>'get','ext'=>'html'],function(){
    Route::group('blog',function(){
        Route::any('blog/:id','blog/read',[],['id'=>'\d+']);
        Route::any('blog/:name','blog/read',[],['name'=>'\w+']);
    }
});

三、路由綁定

1、綁定到模塊/控制器/操作(最多綁定到操作級)
// 綁定當前的URL到 index模塊
Route::bind('index');
// 綁定當前的URL到 index模塊的blog控制器
Route::bind('index/blog');
// 綁定當前的URL到 index模塊的blog控制器的read操作
Route::bind('index/blog/read');

個人:到目前爲止路由綁定的效果使用動態註冊路由沒差別,不過這裏不需要定義路由表達式,即簡單迅捷

http://serverName/index/blog/read/id/5

http://serverName/read/id/5

個人:但路由綁定+註冊路由可以將 模塊、控制器、方法、傳遞的參數名 全部隱藏,而只註冊路由的話只能隱藏 模塊、控制器、傳遞的參數名,還存在一個路由表達式

Route::get('index/blog/:id','index/blog/read');

http://serverName/5
2、綁定到命名空間

個人: 這一個綁定十分的省事,原先做項目時模型和控制器啥的都需要在最上面進行命名空間聲明,而使用命名空間綁定,一個模塊只需要兩句,兩個模塊四句,豈不是超級全局變量?不過單從URL上來說只省略了模塊這一層。

//綁定到命名空間
Route::bind('\app\index\controller','namespace');

只需

http://serverName/blog/read/id/5

就可以直接訪問 \app\index\controller\Blog類的read方法。

3、綁定到類

個人:相比命名空間,這裏單從URL來說省略了模塊、控制器兩層。類似命名空間,單這裏針對的這是控制器層,而命名空間針對的是模塊層

// 綁定到類
Route::bind('\app\index\controller\Blog','class');

只需

http://serverName/read/id/5

就可以直接訪問 \app\index\controller\Blog類的read方法。

注:綁定到命名空間和類之後,不會進行模塊的初始化工作。
4、入口文件綁定

個人:如果我們使用入口文件綁定,綁定一個模塊,同時取消多模塊訪問配置↓,也就意味着,就算你在項目裏放了再多項目也只會訪問一個。想要訪問其他模塊只需要在入口文件改下名字即可。甚至可以使用一個空模塊。將入口文件綁定爲空模塊將實現項目下線功能。

// 是否支持多模塊
'app_multi_module' => true,

只需要入口文件添加BIND_MODULE常量,即可把當前入口文件綁定到指定的模塊或者控制器,例如:

如果我們需要給某個入口文件綁定模塊,可以使用下面兩種方式:
①常量定義
// 定義應用目錄
define('APP_PATH', __DIR__ . '/../application/');
// 綁定到index模塊
define('BIND_MODULE','index');
// 加載框架引導文件
require __DIR__ . '/../thinkphp/start.php';
②自動入口綁定

個人:顧名思義,和①功能一樣,只是這個連綁定都不需要。只需要打開↓配置即可

// 入口自動綁定模塊
'auto_bind_module' => false,

四、域名路由

// blog子域名綁定到blog模塊
Route::domain('blog','blog');
// blog子域名綁定到blog模塊,並添加默認參數
Route::domain('blog','blog?var=thinkphp');

// 原來的URL訪問
http://www.thinkphp.cn/blog/article/read/id/5
// 綁定到blog子域名訪問
http://blog.thinkphp.cn/article/read/id/5

// blog子域名綁定到index模塊的blog控制器
Route::domain('blog','index/blog');

// 原來的URL訪問
http://www.thinkphp.cn/index/blog/read/id/5
// 綁定到blog子域名訪問
http://blog.thinkphp.cn/read/id/5

// 完整域名綁定到admin模塊
Route::domain('admin.thinkphp.cn','admin');
// IP綁定到admin模塊
Route::domain('114.23.4.5','admin');

泛域名部署

二級泛域名
// 綁定泛二級域名域名到book模塊
Route::domain('*','book?name=*');
並且可以直接通過$_GET['name']變量 獲取當前的泛域名。

下面的URL訪問都會直接訪問book模塊
http://hello.thinkphp.cn
http://quickstart.thinkphp.cn
三級泛域名
// 綁定泛三級域名到user模塊
Route::domain('*.user','user?name=*');

如果我們訪問如下URL地址:
http://hello.user.thinkphp.cn
的同時,除了會訪問user模塊之外,還會默認傳入 $_GET['name'] = 'hello'

在配置傳入參數的時候,如果需要使用當前的泛域名作爲參數,可以直接設置爲“*”即可

TP5手冊:https://www.kancloud.cn/manual/thinkphp5/118029

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章