当前位置: 首页 > article >正文

03-OpenFeign-请求传参设置

在使用OpenFeign作为接口调用时,

兼容@RequestMapping 注解,通过动态代理的方式,对接口调用过程中的参数进行封装;

主要的接口传参类型,常用的以下四种:

1、默认@RequestBody Json格式

// 服务方
@RestController
@RequestMapping("/openfeign/provider")
public class OpenFeignProviderController {
    @PostMapping("/order2")
    public Order createOrder2(@RequestBody Order order){
        return order;
    }
}

// 调用方
@FeignClient(value = "openFeign-provider")
public interface OpenFeignService {
    /**     
    * 参数默认是@RequestBody标注的,这里的@RequestBody可以不填     
    * 方法名称任意     
    */
    @PostMapping("/openfeign/provider/order2")
    Order createOrder2(@RequestBody Order order);
}

2、POJO、Map等Form表单形式

@SpringQueryMap

// 服务方
@RestController
@RequestMapping("/openfeign/provider")
public class OpenFeignProviderController {
    @PostMapping("/order1")
    public Order createOrder1(Order order){
        return order;
    }
}

// 调用方
@FeignClient(value = "openFeign-provider")
public interface OpenFeignService {
    /**     
    * 参数默认是@RequestBody标注的,如果通过POJO表单传参的,使用@SpringQueryMap标注     
    */
    @PostMapping("/openfeign/provider/order1")
    Order createOrder1(@SpringQueryMap Order order);
}

3、URL传参

// 服务方
@RestController
@RequestMapping("/openfeign/provider")
public class OpenFeignProviderController {

    @GetMapping("/test/{id}")
    public String test(@PathVariable("id")Integer id){
        return "accept one msg id="+id;
}

// 调用方
@FeignClient(value = "openFeign-provider")
public interface OpenFeignService {

    @GetMapping("/openfeign/provider/test/{id}")
    String get(@PathVariable("id")Integer id);
}

4、普通表单传参

// 服务方
@RestController
@RequestMapping("/openfeign/provider")
public class OpenFeignProviderController {
    @PostMapping("/test2")
    public String test2(String id,String name){
        return MessageFormat.format("accept on msg id={0},name={1}",id,name);
    }
}

// 调用方
@FeignClient(value = "openFeign-provider")
public interface OpenFeignService {
    /**     
    * 必须要@RequestParam注解标注,且value属性必须填上参数名     
    * 方法参数名可以任意,但是@RequestParam注解中的value属性必须和provider中的参数名相同     
    */
    @PostMapping("/openfeign/provider/test2")
    String test(@RequestParam("id") String arg1,@RequestParam("name") String arg2);
}


http://www.kler.cn/a/229082.html

相关文章:

  • 2025.1.15——四、布尔注入
  • 国产编辑器EverEdit - 复制为RTF
  • 使用 Java 实现基于 DFA 算法的敏感词检测
  • 网络IO与IO多路复用
  • 使用 Docker 部署 Java 项目(通俗易懂)
  • Kafka常用命令
  • FPGA(基于xilinx)中PCIe介绍以及IP核XDMA的使用
  • 【视觉领域GPT】SAM:如何使模型能够处理任意图像的分割任务?
  • 【go】延迟执行和定时器实现
  • 非springboot 使用aop 切面
  • HBase相关面试准备问题
  • mysql8通过binlog恢复数据
  • OpenGL 入门(九)—Material(材质)和 光照贴图
  • AS-V1000 视频监控平台产品介绍:客户端功能介绍(二)
  • 算法练习-二叉树的层序遍历(思路+流程图+代码)
  • Docker进阶篇-轻量级可视化工具Portainer
  • 力扣:131. 分割回文串
  • langgraph学习--创建基本的agent执行器
  • 汽车信息安全--SHE中的密钥管理(一)
  • setState的参数
  • 2 月 5 日算法练习- 字符串
  • easyexcel解析跨多行的数据
  • Linux 【docker系列1 - docker 安装与使用】
  • 解决hive表新增的字段查询为空null问题
  • 2.5 作业
  • 从 AGP 4.1.2 升级到 7.5.1——动态添加仓库