@requestMappling注解

@RequestMapping注解用于将HTTP请求映射到控制器方法,可以根据value、method等属性进行精细配置。它可以位于类或方法上,定义处理请求的URL和HTTP方法。例如,通过method属性可以指定GET或POST请求,使用ant风格路径或占位符优化URL。
摘要由CSDN通过智能技术生成

@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}">测@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注解将占位符所标识的值和控制器方法的形参进行绑定(也就是路径中的变量 )。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值