@RequestMapping注解 使用方法 从注解名称上我们可以看到,@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。
SpringMVC 接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理这个请求。
如果在多个controller中对同一个地址进行响应了,那么服务器会进行报错
注解位置
标明了该注解的使用位置可以在类名和方法上
@RequestMapping标识一个类:设置映射请求的请求路径的初始信息
@RequestMapping标识一个方法:设置映射请求请求路径的具体信息
也就是说如果在类名上进行了注解,也在方法名上进行了注解,那么响应的路径就是(类注解地址+方法注解地址)
1 2 3 4 5 6 7 8 9 @Controller @RequestMapping("/test") public class RequestMappingController { @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" ; }
除了上述的请求方式之外,还可以在改变注解的方式,代替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
@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 @RequestMapping("/test/{id}") public String test (@PathVariable("id") Integer id) { System.out.println(id); return "target" ; }