前言
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:空间域名、网页空间、营销软件、网站建设、苍南网站维护、网站推广。
本文主要介绍了关于Spring根据URL参数进行路由的相关内容,分享出来供大家参考学习价值,下面来一起看看详细的介绍吧。
发现问题
最近在写接口的时候发现一个问题,就是两个REST接口的URL的path部分是一样的,根据query传入不同的参数来区分。
比如S3普通上传接口是是:
PUT /{bucketname}/{ objectname}
分块上传的接口是:
PUT /{bucketname}/{objectname}?partNumber={partNumber}&uploadId={uploadId}
传入partNumber和uploadId是一个接口,没有传入这两个参数是另外一个接口,那Spring中要如何进行路由设置呢?
一般我们设置路由都是@RequestMapping(value = "/xx", method = RequestMethod.GET)
。然后在方法签名中可以通过@RequestParam注入参数。
但是直接通过注入不同的参数来实现区分是不行的,比如:
@ResponseBody @RequestMapping(value = "/xx", method = RequestMethod.GET) public String get1(){ return "get1"; } @ResponseBody @RequestMapping(value = "/xx", method = RequestMethod.GET) public String get2(@RequestParam name){ return "get2" + name; }
这样会报错:
java.lang.IllegalStateException: Ambiguous mapping. Cannot map 'DemoController_v01' method public java.lang.String com.nd.sdp.ndss.controller.v01.DemoController.get1() to {[/demo/xx],methods=[GET]}: There is already 'DemoController_v01' bean method
解决方法
意思是重复注册了,所以@RequestParam是不能用来作为路由依据的。
@RequestParam
用来处理Content-Type: 为 application/x-www-form-urlencoded编码的内容。(Http协议中,如果不指定Content-Type,则默认传递的参数就是application/x-www-form-urlencoded类型)
RequestParam可以接受简单类型的属性,也可以接受对象类型。
实质是将Request.getParameter() 中的Key-Value参数Map利用Spring的转化机制ConversionService配置,转化成参数接收对象或字段。
@RequestMapping作为路由注解,除了常用的value字段用于设置url外,还提供了params参数,可以指定如何匹配url中query的参数。又几种配置方法:
这样就可以很灵活的指定路由了。
而且@RequestMapping还提供了headers参数,可以让我们根据Header的情况进行路由!
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对创新互联的支持。