thinkphp-注解路由和URL生成
注解路由
这里仅做记录,推荐使用普通的路由方式 更好理解与管理
继续扩展安装,执行一下命令安装即可
composer require topthink/think-annotation
然后对控制器进行修改
<?php
namespace app\controller;
// 使用use 引入相关类库;
use think\annotation\Route;
class Address
{
/**
* @param $id
* @return string
* @route("ds/:id", ext="html", methods="GET", https=1);
*/
public function details($id)
{
return 'details 目前调用的id:'.$id;
}
}
将路由写在控制器方法的注释里
注意:这里必须使用双引号,单引号会直接报错;@route("details/:id")
第二或以上参数,可以设置请求类型,比如要求是GET 模式访问;更多参数可实现更多功能(不需要考虑顺序),比如ext、https 等;
@route("ds/:id", method="GET")
@route("ds/:id", method="GET", ext="html", https=1) //布尔值0,1 代替
注解模式也支持资源路由,先要use 相关类库,然后声明;
<?php
// 控制代码严格性 严格模式
declare (strict_types = 1);
namespace app\controller;
use think\Request;
use think\annotation\Route\Resource;
/**
* Class Blog
* @package app\controller
* @resource("blog")
*/
class Blog
{}
注解模式也支持分组,先要use 相关类库,然后声明;
use think\annotation\Route;
use think\annotation\route\Group;
* @Group("ads")
URL生成
首先,创建一个新的控制器:controller/Url.php,创建一个路由方法和URL 生成的方法;
<?php
namespace app\controller;
use think\facade\Route;
class Url
{
public function index()
{
return Route::buildUrl('Url/details', [
'id' => 5
]);
}
public function details($id)
{
return 'id:' . $id;
}
}
然后在route/app.php中写入如下路由规则
Route::rule('uu', 'Url/index');
Route::rule('uu/:id', 'Url/details');
如果要在Index方法中获取details的链接
return Route::buildUrl('Url/details', [
'id' => 5
]);
最终返回的结果:/xuexi/tp6/public/uu/5.html
注意:这里的地址和路由的定义是相辅相成的,如果没有定义,地址将会变化;
如果将Route::rule('uu/:id$', 'Url/details');注释掉,那么返回的结果就是
/xuexi/tp6/public/Url/details.html?id=5
也可以给路由定义取一个别名,然后在生成URL 的时候,直接使用这个别名调用;
Route::rule('uu$', 'Url/index');
// 取一个别名u
Route::rule('uu/:id$', 'Url/details')->name('u');
在控制器中调用时候
return Route::buildUrl('u', [
'id' => 5
]);
也可以直接使用路由地址生成URL,但这个方式并不需要和路由定义相匹配;
Route::rule('uu$', 'Url/index');
return Route::buildUrl('ds/5');
由于,我们默认在配置设置了后缀为.html,所以,生成的URL 会自动加上;
return Route::buildUrl('ds/5')->suffix('shtml');
最终结果返回:/xuexi/tp6/public/ds/5.shtml
如果,你想添加完整域名路径,可以再添加domain 方法
return Route::buildUrl('ds/5')->domain(true);
结果就会返回:http://localhost/xuexi/tp6/public/ds/5.html
return Route::buildUrl('ds/5')->domain('news'); // http://news.localhost/xuexi/tp6/public/ds/5.html
return Route::buildUrl('ds/5')->domain('news.abc.com'); http://news.adb.com/xuexi/tp6/public/ds/5.html
return Route::buildUrl('ds/5@news.abc.com'); // http://news.abc.com/xuexi/tp6/public/ds/5.html
也可以直接使用助手函数url()来代替Route::buildUrl()
return url('ds/5');
返回:/xuexi/tp6/public/ds/5.html