一、@RequestMapping注解的功能
从注解的@RequestMapping名称就能知道大概的意思:将请求和处理请求的控制器方法关联起来,建立映射关系。
SpringMVC中接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理这个请求。
二、@RequestMapping注解的位置
我们可以查看一下@RequestMapping的源码来进行分析:
@Target({ElementType.TYPE, ElementType.METHOD})
通过上面两个参数我们能知道@RequestMapping这个注解能够标示在 类和方法 上面。而表示在不同的地方则作用也是不一样的。
接下来我们通过一些例子来进行分析。
注解在方法上:
@Controller public class hello { @RequestMapping("/hello") public String hello(){ return "hello"; }
运行结果:
当标示在方法时,这个就直接和我们的服务器请求发生相关联,就能匹配所发送的请求。
OK,接下来我们标示在类上面时:
@Controller @RequestMapping("MVC") public class hello { @RequestMapping("/hello") public String hello(){ return "hello"; }
当我们还是和上面上面一样对:(http://localhost:8080/SpringMVC/hello)这个地址进行请求时则会发生什么呢?
运行结果:
能看见服务器是直接给我们报404。则当我们在hello前面加上一个MVC时,来看看结果。
运行结果:
则是能够请求成功的,所以我们大概能理解了如果在类上标示后就会多了一个初始化路径。
总结:
@RequestMapping标识一个类:设置映射请求的请求路径的初始信息
@RequestMapping标识一个方法:设置映射请求请求路径的具体信息
三、@RequestMapping注解的name属性
name属性: 方法注释。
例如:
@RequestMapping(value = "login",name = "用户登录") public String login() { return "success"; }
这个目前还是比较少见了,因为是作用在jsp上,所以这个大家可以了解了解。面试的时候也可能会被问题到SpringMVC的属性有哪些,这个就可以作为一个回答。
四、@RequestMapping注解的value属性
value属性的值是一个String数组,他能设置多个值,使得多个请求地址指向同一个资源
如果出错,会报 404找不到资源。
正如在上面的例子我们是直接把value省略直接写的属性值。一般还是需要加上去。
public class hello { @RequestMapping(value = "/hello") public String hello(){ return "hello"; }
使用多个请求地址:
@Controller public class hello { @RequestMapping(value = {"/hello","/Hello"}) public String hello(){ return "hello"; }
当我们访问hello时:
当我们访问Hello时;
通过上面的两个例子我们能知道他们请求的是同一个资源。
五、@RequestMapping注解的method属性
method 的方法一般有: GET、POST、PUT、DELETE等;
@RequestMapping注解的 method 属性是一个 RequestMethod 类型的数组,表示该请求映射能够匹配多种请求方式的请求。
注: 如果请求方式是不满足 RequestMethod 中的请求方法,则浏览器报错405:Request method ‘POST’ not supported。
使用案例:
@Controller public class hello { @RequestMapping( value = {"/hello","/Hello"}, method = {RequestMethod.GET, RequestMethod.POST} ) public String hello(){ return "hello"; }
上述代码我们能看到这个请求资源是可以接收GET,POST方法的。在之前我们都是没有加这个 method 参数的但是我们还是能够对这个资源进行请求的原因就是因为在默认情况下,则是可以接收任何的请求方式。
补充:
1、在 SpringMVC 中还有@RequestMapping的一些派生注解:
处理get请求—GetMapping。
处理post请求— PostMapping。
处理put请求— PutMapping。
处理delete请求— DeleteMapping。
2、刚才提到了常用的请求有 get、post、put和delete 。但是在服务器中只接受 get 请求和 post 请求,如果在使用了from表单时使用了其他方法的话,则都会按照默认方法 get 来进行处理。
如果需要发送 put或者delete请求,则需要用到Spring中的过滤器HiddenHttpMethodFilter。
六、@RequestMapping注解的Params属性
该属性指定,请求中必须包含params属性规定的参数时,才能执行该请求。
”params“ — 请求必须携带 params 参数。
”!params“—请求 不能 携带 params 参数。
“params = value” —请求 必须 携带参数,且参数 params 是等于 value 的。
”!params = value“ —请求 必须 携带参数,且参数 params 是不等于 value的。
测试案例:
<a th:href="@{/test(username = 'admir',password = 31)}">测试params</a>
@RequestMapping( value = "/test", params = "!username", ) public String testParams(){ return "success"; }
通过代码我们能得到我们是必须需要请求不能携带参数的,如果携带参数就会出现错误。
运行结果: