@RequestMapping
1、作用
用于建立请求URL和处理请求方法之间的对应关系
2、标识位置
1)类上,请求URL的第一级访问目录。此处不写的话,就相当于应用的根目录
2)方法上,请求URL的第二级访问目录, 与类上的使用@ReqquestMapping标注的一级目录一起组成访问虛拟路径
3、属性
(1)value
用于指定请求的URL,value和path属性的作用是一样的,互为别名(Alias)
(2)method:用于指定请求的方式。无法满足该要求,405
-
派生注解:
@GetMapping、@PostMapping、@PutMapping、@DeleteMapping
//登录请求,地址为"/login",要求参数必须携带账号与密码,且请求方法类型必须为Post @PostMapping(value = "/login",params = {"account","pwd"}) public String login() { return "login"; }
(3)params:用于指定限制请求参数的条件。支持简单的表达式。要求请求参数的key和value必须和配置的一模一样。不满足要求400
-
1、params = {“account”,“pwd”}:参数必须携带账号与密码
-
2、!params = {“id”}:参数不能携带ID
-
3、params = {“account = zhangsan@test”}:参数必须携带账号,且账号必须是"zhangsan@test"
-
4、params = {“account != admin@test”}:参数必须携带账号,且账号不能是"admin@test"
-
4)headers:用于限制请求头。支持简单的表达式。条件表达式方式类似于params。不满足要求404
风格支持
(1)ant风格
-
?:表示任意的单个字符
-
*:表示任意的0个或多个字符
-
**:表示任意的一层或多层目录
注意:在使用**时,只能使用/**/xxx
的方式
比如:/**/{videoId}
,可以通过/{videoId}
、/video/{videoId}
、/medialist/play/watchlater/{videoId}
等定位
(2)RESTful风格
-
原始方式:
/deleteUser?id=1
-
rest方式:
DELETE /user/1
当请求路径中将某些数据通过路径的方式传输到服务器中,就可以在相应的@RequestMapping注解的value属性中通过占位符{xxx}表示传输的数据,再通过@PathVariable
注解,将占位符所表示的数据赋值给控制器方法的形参
/** GET http://localhost:8888/learn/user/{id} */
@GetMapping("/{id}")
public User getUserById(@PathVariable String id) {
Long userId = Long.parseLong(id);
return userService.getUserById(userId);
}