java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringMVC @RequestMapping注解

SpringMVC中@RequestMapping注解的实现

作者:thdwx

RequestMapping是一个用来处理请求地址映射的注解,本文主要介绍了SpringMVC中@RequestMapping注解的实现,具有一定的参考价值,感兴趣的可以了解一下

0. 多个方法对应同一个请求

@RequestMapping("/")
    public String toIndex(){
        return "index";
    }
    
    @RequestMapping("/")
    public String toIndex2(){
        return "index";
    }

这种情况是不允许的,会报错。

在这里插入图片描述

1. 注解的功能

@RequestMapping注解的作用就是将请求地址和处理请求的控制器方法关联起来,建立映射关系。
SpringMVC接收到指定的请求,就会找到映射关系中对应的控制器方法来处理这个请求。

2. 注解位置

@RequestMapping注解既可以放在方法上,也可以放在类上。
标识方法:设置映射的请求路径的具体信息。
标识类:设置映射的请求路径的初始信息。
例如:如果有如下代码

@RequestMapping("/hello")
@Controller
public class TestRequestMapping {
    @RequestMapping("/target")
    public String toTarget(){
        return "target";
    }
}

那么在访问target之前必须加上/hello,否则访问不到target,也就是url为 http://localhost:8080/项目上下文路径/hello/target

在这里插入图片描述

在这里插入图片描述

3. value属性

    @RequestMapping({"/test1","/test2"})
    public String toTestValue(){
        return "testValue";
    }
<a th:href="@{/test1}" rel="external nofollow" >一个控制器方法匹配多个value测试1</a><br>
<a th:href="@{/test2}" rel="external nofollow" >一个控制器方法匹配多个value测试2</a><br>

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

4. method属性

@RequestMapping(value="/test3",method=RequestMethod.POST)
    public String toTestMethod(){
        return "testMethod";
    }
<a th:href="@{/test3}" rel="external nofollow" >method允许POST请求测试</a><br>
<form method="POST" th:action="@{/test3}">
    username<input name="username" type="text" /><br>
    <input type="submit" value="提交" /><br>
</form>
<form method="DELETE" th:action="@{/test3}">
    username<input name="username" type="text" /><br>
    <input type="submit" value="提交" /><br>
</form>

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

5. params属性

    /*这个注解表示请求参数要满足如下要求
    1.要有username1,值任意
    2.不能有username2
    3.要有username3,且值为jack
    4.要有username4,且值不能为jack
    在写键值对时,如果value为字符串类型,不需要使用单引号括起来,否则会出错
     */
    @RequestMapping(value="/test4",params={"username1","!username2","username3=jack","username4!=jack"})
    public String toTestParams(){
        return "testParams";
    }
<!--使用?可以连接请求参数,但是会标红,所以可以使用括号来表示请求参数-->
<a th:href="@{/test4(username3='jack',username4='asd')}" rel="external nofollow" >Params没有username1测试</a><br>
<a th:href="@{/test4(username1='asd',username2='qw',username3='jack',username4='qew')}" rel="external nofollow" >Params有username2测试</a><br>
<a th:href="@{/test4(username1='dg',username3='asd',username4='oih')}" rel="external nofollow" >Params有username3但值不为jack测试</a><br>
<a th:href="@{/test4(username1='ih',username3='jack',username4='jack')}" rel="external nofollow" >Params有username4但值为jack测试</a><br>
<a th:href="@{/test4(username1='asd',username3='jack',username4='xcv')}" rel="external nofollow" >Params参数满足条件测试</a><br>

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

6. headers属性

    @RequestMapping(value="/test5",headers = {"Host=localhost:8080","Accept-Encoding!=gzip, deflate, br"})
    public String toTestHeaders(){
        return "testHeaders";
    }
<a th:href="@{/test5}" rel="external nofollow" >Headers不满足Accept-Encoding条件</a><br>

在这里插入图片描述

修改headers属性后,可以使条件满足:

    @RequestMapping(value="/test5",headers = {"Host=localhost:8080","Accept-Encoding=gzip, deflate, br"})
    public String toTestHeaders(){
        return "testHeaders";
    }

在这里插入图片描述

7. ant风格的路径

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

8. 路径中的占位符

SpringMVC路径中的占位符常用于RESTful风格中,它允许将参数作为路径的一部分发送给服务器,而不是以?连接在URL后。该方式传递的参数只能通过@PathVariable注解的value属性中的同名变量获得参数值。

    //大括号表示占位符
    @RequestMapping("/test6/{id}/{username}")
    public String toTest(@PathVariable("id")Integer id,@PathVariable("username")String username){
        System.out.println("id = "+id+"  "+"username = "+username);
        return "test";
    }

在这里插入图片描述

到此这篇关于SpringMVC中@RequestMapping注解的实现的文章就介绍到这了,更多相关SpringMVC @RequestMapping注解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文