java中@requestMappling注解的使用

@RequestMapping注解的作用

从注解名称上我们可以看到

@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。

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

@RequestMapping注解的位置

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

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

controller控制层

处理首页的控制层(标识在方法上)

@Controller
public class ProtalController {
    @RequestMapping("/")
    public String protal(){
        return "index";
    }
}

标识在类上和方法

@Controller
//标记到类上,设置当前请求映射的基础信息,方法上是具体信息
@RequestMapping("/test")
public class TestRequestMapplingController {
//    控制器方法所配置的请求的请求路径为/test/hello
    @RequestMapping("/hello")
    public String hello(){
        return "success";
    }
}

thymeleaf渲染页面(index.html)

<body>
<h1>index.html</h1>
<a th:href="@{/hello}" rel="external nofollow" >测@RquestMappling标识注解的位置</a>
</body>

跳转的页面)(success,html)

<body>
<h1>跳转成功</h1>
</body>

@RequestMapping注解的value属性

value属性通过请求的请求地址匹配请求映射。

value属性是一个字符串类型的数组,

即当前浏览器所发送的请求路径匹配value属性中的任何一个值

则当前请求就会被注解所标识的方法进行处理。

value属性必须设置,至少通过请求地址匹配请求映射。

@Controller
public class TestRequestMapplingController {
    @RequestMapping({"/hello","/second"})
    public String hello(){
        return "success";
    }
}

@RequestMapping注解的method属性

作用:@RequestMapping注解的method属性是一个RequestMethod类型的 数组,表示该请求映射能够匹配多种请求方式的请求。

规定控制器的方法在请求路径匹配的情况下,当前控制器方法处理请求的请求方式是什么?

当前请求路径和请求方式都能匹配,控制器方法才能处理这个请求。

注意:

通过请求的请求方式匹配请求。

当前浏览器所发送的请求方式匹配method属性中的任何一种请求方式,

则当前请求就会被注解所标识的方法进行处理。

若浏览器所发送的请求的请求路径和@RequestMapping注解value属性匹配,

但是请求方式不匹配此时,页面报错:405.....

get和post请求都可以匹配:method = {RequestMethod.GET,RequestMethod.POST}

@RequestMapping注解的method属性通过请求的请求方式 (get或post) 匹配请求映射。

@RequestMapping(value = {"/hello","/second"},method = RequestMethod.GET )
    public String hello(){
        return "success";
    }

@RequestMapping注解使用ant风格路径

?:表示任意的单个字符

注意:? 是当前请求路径中路径和参数分割符,所以地址中 ?前面才是路径,? 后面当成请求参数

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

** :表示任意层数的任意目录

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

    @RequestMapping("/a?a/test/ant")
    public String testAnt(){
        return "success";
    }

thymeleaf渲染页面

<a th:href="@{/aaa/test/ant}">测试测@RquestMappling注解支持ant风格路径</a>

@RequestMapping注解使用路径中的占位符

原始方式:/deleteUser?id=1

rest方式:/user/delete/1

把传输服务器参数(例如下面的admin/1这两个参数)也作为路径一部分,传输到服务器中。

会把所有的内容全部体现在路径中,把id值传过去就不用id和 ?

用原始方式是键值对,用rest方式该如何获取?,

就需要使用路径中的占位符和@PathVariable注解。

thymeleaf渲染

<a th:href="@{/test/rest/admin/1}">测试测@RquestMappling的value属性的占位符</a>

controller控制器

// {id}:占位符
    @RequestMapping("/test/rest/{username}/{id}")
    public String testRest(@PathVariable("id") Integer id,@PathVariable("username") String username){
        System.out.println("id:"+id+"username:"+username);
        return "success";
    }

即匹配到当前请求映射,还要在控制器方法中获取传递过去的请求参数

以前是name=value,现在只有value。

只需要在控制器方法里面获取占位符id这个值,赋值到参数里面,

所以需要在@RequestMapping注解的value属性中设置的路径中,使用{xx}的方式表示路径中的数据,和通过@PathVariable注解将占位符所标识的值和控制器方法的形参进行绑定(也就是路径中的变量 )。

原文地址:https://blog.csdn.net/zjw_rp/article/details/128674109