RequestMapping注解
@RequestMapping注解
使用方法
从注解名称上我们可以看到,@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。
SpringMVC 接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理这个请求。
如果在多个controller中对同一个地址进行响应了,那么服务器会进行报错
注解位置
标明了该注解的使用位置可以在类名和方法上
@RequestMapping标识一个类:设置映射请求的请求路径的初始信息
@RequestMapping标识一个方法:设置映射请求请求路径的具体信息
也就是说如果在类名上进行了注解,也在方法名上进行了注解,那么响应的路径就是(类注解地址+方法注解地址)
1 |
|
属性
value
1 |
两个请求的地址都可以被这个方法检测并且运行,其他的属性都可以不进行设置,但是value必须进行设置
method属性
通过请求的方法(get与post)进行响应,但是如果我们不设置请求的方法限制,那么我们的方法get请求与post请求都不会拒绝
比如我们知道网页中默认的都是get请求,那么控制器中的方法接受也是以默认get方法吗???
我们会发现网页还是会跳转成功,但是一旦我们给他加上的方法限制,那么请求必须符合才可以通过
1 | method = RequestMethod.GET |
1 |
|
1 |
|
除了上述的请求方式之外,还可以在改变注解的方式,代替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 | <form th:action="@{/target}" method="post"> |
1 |
|
如果我输入password=123456
headers
@RequestMapping注解的headers属性通过请求的请求头信息匹配请求映射,即与我们的http协议中的请求头对应,我们可以设置请求头必须携带那一部分东西
1 |
协议中必须携带host为8080的主机地址
SpringMVC支持ant风格的路径
?:表示任意的单个字符—->a?a/target,可任意访问a1a/target,alatarget等等路径,但是不能代替?,/等单个字符
*:表示任意的0个或多个字符
**:表示任意的一层或多层目录
注意:在使用**时,只能使用/**/xxx的方式,
SpringMVC支持路径中的占位符(重点)
1 | <a th:href="@{/test/1}">hehie</a> |
1 | //接受test/(参数)的地址 |