- 路由
- RequestMapping 注解
- route参数
- method参数
- RequestMapping 注解
- 使用说明
路由
Swoft与传统的PHP框架不一样,并没有采用配置文件的方式来配置路由,而采用了注解。
在Swoft里我们可以
RequestMapping 注解
- route:路由规则
- method:请求方式(GET、POST、PUT、PATCH、DELETE、OPTIONS、HEAD)
route参数
使用方法在控制器方法中加入 RequestMapping
注解
/**
* @RequestMapping()
* @RequestMapping("index")
* @RequestMapping(route="index")
* @RequestMapping(route="/index/{name}")
* @RequestMapping(route="/index[/{name}]")
*/
public function index(string $name){}
- 显示指定路由后缀:
@RequestMapping("index")
或 @RequestMapping(route=”index”) - 隐式指定路由后缀: 不使用 @RequestMapping 或者使用 @RequestMapping(), 默认解析方法名为后缀
- 指定路由参数: @RequestMapping(route=”index/{name}”),Action 方法中可以直接使用 $name 作为方法参数,当路由参数被
[]
包起来则URL传递参数可有可无
method参数
决定被请求控制器的操作允许哪种请求方式,使用方法在控制器中的 RequestMapping
注解配置method参数,
/**
* @RequestMapping(method={RequestMethod::GET})
* @RequestMapping(method={RequestMethod::GET,RequestMethod::POST})
*/
public function index(){}
- 限定HTTP方法: @RequestMapping(method={RequestMethod::GET}) 指定路由支持的HTTP方法,默认是支持GET和POST
- 比如 method={RequestMethod::POST,RequestMethod::PUT} 设置路由支持 POST 和 PUT
使用说明
- 通常一个完整的路由path等于 Controller的
prefix
+ Action的route
- 当你的action上的路由以 / 开头时,那完整的路由就是它,即不会再将 prefix 添加到它的前面。
- 请切记要引入相关的注解类