RequestMapping注解

@RequestMapping注解

使用方法

从注解名称上我们可以看到,@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。

SpringMVC 接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理这个请求。

如果在多个controller中对同一个地址进行响应了,那么服务器会进行报错

注解位置

image-20220423200039239

标明了该注解的使用位置可以在类名和方法上

@RequestMapping标识一个类:设置映射请求的请求路径的初始信息

@RequestMapping标识一个方法:设置映射请求请求路径的具体信息

也就是说如果在类名上进行了注解,也在方法名上进行了注解,那么响应的路径就是(类注解地址+方法注解地址)

1
2
3
4
5
6
7
8
9
@Controller
@RequestMapping("/test")
public class RequestMappingController {
//此时请求映射所映射的请求的请求路径为:/test/testRequestMapping
@RequestMapping("/testRequestMapping")
public String testRequestMapping(){
return "success";
}
}

属性

value

1
@RequestMapping( value = {"/","/hi"})

两个请求的地址都可以被这个方法检测并且运行,其他的属性都可以不进行设置,但是value必须进行设置

method属性

通过请求的方法(get与post)进行响应,但是如果我们不设置请求的方法限制,那么我们的方法get请求与post请求都不会拒绝

比如我们知道网页中默认的都是get请求,那么控制器中的方法接受也是以默认get方法吗???

我们会发现网页还是会跳转成功,但是一旦我们给他加上的方法限制,那么请求必须符合才可以通过

1
method = RequestMethod.GET
1
2
3
4
5
6
7
8
9
10
11
12
13
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>主页面</title>
</head>
<body>
你好世界
<form th:action="@{/target}" method="post">
<input type="submit" value="以post方式提交表单">
</form>
</body>
</html>
1
2
3
4
@RequestMapping("/target")
public String toTarget(){
return "target";
}

image-20220423203158051

除了上述的请求方式之外,还可以在改变注解的方式,代替method方法

处理get请求的映射–>@GetMapping

处理post请求的映射–>@PostMapping

处理put请求的映射–>@PutMapping

处理delete请求的映射–>@DeleteMapping

但是注意,如果我们使用put或者delete方式进行表单提交,那么浏览器默认使用get方式进行请求,那么在响应的方法中如果定义了只能接受put方式,那么会发生错误

params

我们设置的请求的参数必须同时满足,我们才可以进行使用

“param”:要求请求映射所匹配的请求必须携带param请求参数

“!param”:要求请求映射所匹配的请求必须不能携带param请求参数

“param=value”:要求请求映射所匹配的请求必须携带param请求参数且param=value

“param!=value”:要求请求映射所匹配的请求必须携带param请求参数但是param!=value

1
2
3
4
5
<form th:action="@{/target}" method="post">
<input type="submit" value="以post方式提交表单">
<input type="text" name="username">
<input type="text" name="password">
</form>
1
2
3
4
5
6
7
@RequestMapping(value = "/target",
method = RequestMethod.POST,
params = {"username","password!=123456"}
)
public String toTarget(){
return "target";
}

如果我输入password=123456

image-20220423205229674

headers

@RequestMapping注解的headers属性通过请求的请求头信息匹配请求映射,即与我们的http协议中的请求头对应,我们可以设置请求头必须携带那一部分东西

1
2
3
4
5
@RequestMapping(value = "/target",
method = RequestMethod.POST,
params = {"username","password!=123456"},
headers = {"Host=localhost:8080"}
)

协议中必须携带host为8080的主机地址

SpringMVC支持ant风格的路径

?:表示任意的单个字符—->a?a/target,可任意访问a1a/target,alatarget等等路径,但是不能代替?,/等单个字符

*:表示任意的0个或多个字符

**:表示任意的一层或多层目录

注意:在使用**时,只能使用/**/xxx的方式,

SpringMVC支持路径中的占位符(重点)

1
<a th:href="@{/test/1}">hehie</a>
1
2
3
4
5
6
7
//接受test/(参数)的地址
@RequestMapping("/test/{id}")
//将id标记为Integer id的对应信息
public String test(@PathVariable("id")Integer id){
System.out.println(id);
return "target";
}