java

关注公众号 jb51net

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

java中@requestMappling注解的使用

作者:zjw_rp

本文主要介绍了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注解将占位符所标识的值和控制器方法的形参进行绑定(也就是路径中的变量 )。

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

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