springMVC请求映射

SpringMVC中,如何处理请求是很重要的任务。请求映射都会使用@RequestMapping标注。其中,类上的标注相当于一个前缀,表示该处理器是处理同一类请求;方法上的标注则更加细化。如,类的标注可能是“user”,表示全部都是与用户相关的操作;具体到方法可能有“create”“update”“delete”等,分别表示对用户进行哪一类操作。

复制代码
package cn.javass.chapter6.web.controller;  
@Controller  
@RequestMapping(value="/user")                 //①处理器的通用映射前缀  
public class HelloWorldController2 {  
    @RequestMapping(value = "/hello2")        //②相对于①处的映射进行窄化  
    public ModelAndView helloWorld() {  
         //省略实现  
    }  
}  
复制代码

现在就来总结一下请求映射有哪些。

一、URL路径映射

这种映射涉及的属性只有value。

@RequestMapping(value={"/test1", "/user/create"}) //或,表示多个路径都可以映射到同一个处理方法
@RequestMapping(value="/users/{userId}/topics/{topicId}") //也可以使用大括号,表示变量占位符
@RequestMapping(value="/product?") //可匹配“/product1”或“/producta”,但不匹配“/product”或“/productaa”
@RequestMapping(value="/products/**/{productId}") //可匹配“/products/abc/abc/123”或“/products/123”
@RequestMapping(value="/products/{categoryCode:\\d+}-{pageNumber:\\d+}") //支持正则表达式

二、请求方法映射限定

不仅要提供value属性,还要提供method属性。

@RequestMapping(value="/create", method = RequestMethod.GET) //表示可处理匹配“/create”且请求方法为“GET”的请求
@RequestMapping(value="/create", method = RequestMethod.POST) //表示可处理匹配“/create”且请求方法为“POST”的请求

一般浏览器仅支持GET和POST类型,其他如PUT、DELETE等需要进行模拟。

三、请求参数映射限定

需要提供params属性和method属性。

以下面的控制器为例,

@Controller  
@RequestMapping("/parameter1")       //①处理器的通用映射前缀  
public class RequestParameterController1 {
    // Something...
}
复制代码
@RequestMapping(params="create", method=RequestMethod.GET) //表示请求中有“create”的参数名且请求方法为“GET”即可匹配,
                                                             如可匹配的请求URL“http://×××/parameter1?create”

@RequestMapping(params="create", method=RequestMethod.POST) //表示请求中有“create”的参数名且请求方法为“POST”即可匹配

@RequestMapping(params="!create", method=RequestMethod.GET) //表示请求中没有“create”参数名且请求方法为“GET”即可匹配,
                                                              如可匹配的请求URL“http://×××/parameter1?abc”

@RequestMapping(params="submitFlag=create", method=RequestMethod.GET) //表示请求中有“submitFlag=create”请求参数且请求方法为“GET”即可匹配,
                                                                        如请求URL为http://×××/parameter2?submitFlag=create

@RequestMapping(params="submitFlag=create", method=RequestMethod.POST) //表示请求中有“submitFlag=create”请求参数且请求方法为“POST”即可匹配

@RequestMapping(params="submitFlag=create", method=RequestMethod.GET) //表示请求中有“submitFlag=create”请求参数且请求方法为“GET”即可匹配,
                                                                        如请求URL为http://×××/parameter2?submitFlag=create
复制代码

与value中的参数组合表示“或”不同,params参数组合表示“且”,即:

@RequestMapping(params={"test1", "test2=create"}) //表示请求中的有“test1”参数名 且 有“test2=create”参数即可匹配,如可匹配的请求URL“http://×××/parameter3?test1&test2=create
Spring MVC提供了多种请求映射注解来指定处理请求的地址。其中常用的注解包括: - `@RequestMapping`:通用的请求处理类,可以用在类和方法上。 - `@GetMapping`:处理HTTP GET请求的查询方法。 - `@PostMapping`:处理HTTP POST请求的新增或修改方法。 - `@PutMapping`:处理HTTP PUT请求的新增或修改方法。 - `@PatchMapping`:处理HTTP PATCH请求的新增或修改方法。 - `@DeleteMapping`:处理HTTP DELETE请求的删除方法。 注意,当类和方法上都添加了`@RequestMapping`注解时,前端发送请求时,需要将两个注解的value值相加匹配才能访问到对应的处理方法。而且,`@RequestMapping`注解的value属性前面加不加斜杠都可以。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringMVC请求映射注解](https://blog.csdn.net/weixin_56295084/article/details/115695830)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [SpringMVCSpringMVC请求映射路径(3)](https://blog.csdn.net/qq_43751200/article/details/128340053)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [SpringMVC请求映射原理](https://blog.csdn.net/weixin_43808717/article/details/118345382)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值