Feign调用接口时,都是需要进行参数传递的,一般可以分为两类
- 字符串参数传递,比如xml、json、string等
- 对象参数传递
字符串参数传递(@RequestParam)
@RequestParam注解用来接收字符串类型参数,有以下注意点
- 客户端@RequestParam注解的value属性必须指定值,不能为空,且要和服务端接口参数名保持一致
- 如果需要传递多个字符串参数,则使用多个@RequestParam注解与服务端接口参数保持一一对应即可
服务端
@ResponseBody @PostMapping(value = "check") public CheckAckVo check(String jsonParam) { FileCheckVo fileCheckVo = JacksonUtil.jsonToBean(jsonParam, FileCheckVo.class); return checkAck(taskId, OpStatusEnum.SUCCESS.getCode()); }
客户端
@FeignClient(value = "act-engine-web", fallbackFactory = PlatformUserFeignServiceFallBack.class) public interface PlatformUserFeignService { @RequestMapping(value = "/engine/check", method = RequestMethod.POST) String check(@RequestParam(value = "jsonParam") String jsonParam); }
对象参数传递(@RequestBody )
@RequestBody注解用来接收字符串类型参数,有以下注意点
- @RequestBody 注解在服务端和客户端都需要使用
- 参数名和参数类型在服务端和客户端需要保持一致
服务端
@ResponseBody @PostMapping(value = "check") public CheckAckVo check(@RequestBody FileCheckVo fileCheckVo) { //使用对象参数传递,则不需要再使用jackson进行转化 //FileCheckVo fileCheckVo = JacksonUtil.jsonToBean(jsonParam, FileCheckVo.class); return checkAck(taskId, OpStatusEnum.SUCCESS.getCode()); }
客户端
@FeignClient(value = "act-engine-web", fallbackFactory = PlatformUserFeignServiceFallBack.class) public interface PlatformUserFeignService { @RequestMapping(value = "/engine/check", method = RequestMethod.POST) String check(@RequestBody FileCheckVo fileCheckVo); }
思考
- @RequestBody 进行对象参数传递时,需要引入参数类型依赖(FileCheckVo),此时最好是将这个依赖放入公共依赖包中,否则会增加服务端和客户端的耦合度。
- 个人感觉@RequestBody 更多的用于系统间进行文件传递等(将文件读为byte数组,和其他属性组装成一个对象进行传递)