@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);
}
本文详细介绍了Spring MVC框架中@RequestMapping注解的功能与用法,包括其作用、标识位置、属性及风格支持等内容,并提供了具体的示例代码。
6644

被折叠的 条评论
为什么被折叠?



