SpringCloud Feign参数问题及解决方法
这篇文章主要介绍了SpringCloudFeign参数问题及解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
今天遇到使用Feign调用微服务,传递参数时遇到几个问题
1.无参数
以GET方式请求
服务提供者
@RequestMapping("/hello")
publicStringHello(){
return"hello,provider";
}
服务消费者
@GetMapping("/hello")
Stringhello();
2.单个参数
(1)GET——@PathVariable
服务提供者
@GetMapping("/test/{name}")
publicStringtest(@PathVariableStringname){
return"hello,"+name;
}
服务消费者
@GetMapping("/test/{name}")
Stringtest(@PathVariable("name")Stringname);
(2)GET——@RequestParam
服务提供者
@RequestMapping("/test")
publicStringtest(Stringname){return"hello,"+name;
}
服务消费者
@RequestMapping("/test")
Stringtest(@RequestParamStringname);
会遇到报错
RequestParam.value()wasemptyonparameter0
解决方法:
加上注解的描述,修改为
@RequestMapping("/test")
Stringtest(@RequestParam("name")Stringname);
(3)POST
@RequestBody
不需要注解的描述
@RequestMapping("/test")
Stringtest(@RequestBodyStringname);
注:
- 参数前使用了@RequestBody注解的,都以POST方式消费服务
- @RequestBody注解的参数,需要POST方式才能传递数据
2.Feign多参数的问题
(1)GET——@PathVariable
服务提供者
@GetMapping("/test/{name}/{xyz}")
publicStringtest(@PathVariableStringname,@PathVariableStringxyz){
return"hello,"+name+","+xyz;
}
服务消费者
@GetMapping("/test/{name}/{xyz}")
Stringtest(@PathVariable("name")Stringname,@PathVariable("xyz")Stringxyz);
(1)GET——@RequestParam
服务提供者
@RequestMapping("/test")
publicStringtest(Stringname,Integertype){
if(type==1){
return"hello,"+name;
}else{
return"hello,provider-"+name;
}
}
服务消费者
@RequestMapping("/test")
Stringtest(Stringname,Integertype);
会遇到报错MethodhastoomanyBodyparameters
说明:
如果服务消费者传过来参数时,全都用的是@RequestParam的话,那么服务提供者的Controller中对应参数前可以写@RequestParam,也可以不写
服务消费者feign调用时,在所有参数前加上@RequestParam注解
正确的写法
@RequestMapping("/test")
Stringtest(@RequestParam("name")Stringname,@RequestParam("type")Integertype);
(2)POST
如果接收方不变
服务消费者
@RequestMapping("/test")
Stringtest(@RequestBodyStringname,@RequestBodyIntegertype);
会遇到报错MethodhastoomanyBodyparameters
服务消费者为
@RequestMapping("/test")
Stringtest(@RequestBodyStringname,@RequestParam("type")Integertype);
name的值会为null
说明:
如果服务消费者传过来参数,有@RequestBody的话,那么服务提供者的Controller中对应参数前必须要写@RequestBody
正确的写法
服务提供者
@RequestMapping("/test")
publicStringtest(@RequestBodyStringname,Integertype){
if(type==1){
return"hello,"+name;
}else{
return"hello,provider-"+name;
}
}
服务消费者正确的写法
@RequestMapping("/test")
Stringtest(@RequestBodyStringname,@RequestParam("type")Integertype);
可以接收到参数
总结:
- 请求参数前加上注解@PathVariable、@RequestParam或@RequestBody修饰
- 可以有多个@RequestParam,但只能有不超过一个@RequestBody
- 使用@RequestParam注解时必须要在后面加上参数名
- @RequestBody用来修饰对象,但是既有@RequestBody也有@RequestParam,那么参数就要放在请求的url中,@RequestBody修饰的就要放在提交对象中
- 当参数比较复杂时,feign即使声明为get请求也会强行使用post请求
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。
