(转载)SpringCloud使用feign时的复杂参数传递

Feign传参注意

最近在用SpringCloud尝试重构以前的项目,使用Feign客户端组件来调用微服务,经常出现参数传不过去变成null的问题,网上查了一下发现feign在参数上的使用还是有一定的限制的,主要是要注意:

  1. 当参数比较复杂时,feign即使声明为get请求也会强行使用post请求

  2. 不支持@GetMapping类似注解声明请求,需使用@RequestMapping(value = "url",method = RequestMethod.GET)

  3. 使用@RequestParam注解时必须要在后面加上参数名

写了一个简单案例,同时传输一个对象和一个字符串作为请求参数,

消费端controller

package com.taotao.feignchuanzhi.controller;

import com.sun.org.apache.xerces.internal.xs.datatypes.ObjectList;
import com.taotao.feignchuanzhi.entity.User;
import com.taotao.feignchuanzhi.service.FeignService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.ArrayList;
import java.util.List;

@RestController
public class FeignController {
  @Autowired
    private FeignService feignService;
//String 类型传值通过feign传递
    @RequestMapping("/getOrderName")
    public  String getOrderName(String name){
        return  feignService.getName(name);
    }

  /**
     * feign 多个参数传值
     * @param name
     * @param pass
     * @return
     */

  @RequestMapping("/getOrderNameMore")
    public  String getOrderNameMore(String name,String pass){
        return  feignService.getNameMore(name,pass);
    }


    /**
     * feign 传递 model 类型的值
     * @param user
     * @return
     */

    @RequestMapping("/getuserOrder")
     public String user(User user){
        return feignService.getUser(user);
 }



}

feignService

package com.taotao.feignchuanzhi.service;

import com.taotao.feignchuanzhi.entity.User;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;

import java.util.List;

@FeignClient("app-itmayiedu-member")
public interface FeignService {
  /**
     *  feign 传递 string 类型的值
     * @RequestParam("name") String name  必须要有
     * 也可以 @RequestParam(value="name") String name  + value
     *
     * @param name
     * @return
     */
  @RequestMapping("/getName")
    public String getName(@RequestParam("name") String name);  //必须加上@RequestParam("name") 才能传值

    /**
     * feign 多个参数传值
     * @param name
     * @param pass
     * @return
     */

   @RequestMapping("/getNameMore")
    public String getNameMore(@RequestParam("name") String name,@RequestParam(value="pass") String pass);  //必须加上@RequestParam("name") 才能传值


    /**
     * feign 传递 model 类型的值
     * @param user
     * @RequestBody  必须要有
     * @return
     */

         @RequestMapping("/getUser")
      public String getUser(@RequestBody User user);


}

会员端被调用的controller

package com.taotao.springcloud_erueka_member.controller;

import com.taotao.springcloud_erueka_member.entity.User;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;
import java.util.Map;

@RestController
public class MemberController {
    @Value("${server.port}")
    private  String port;
@RequestMapping("/getMember")
    public String getMember(){
        return  "this is getMember,端口为:"  +port;
    }

    /**
     * 传递 String  类型的值
     * @param name
     * @return
     */
    @RequestMapping("/getName")
    public String getName(String name){
    return  "feign传递参数"+name;
    }

    /**
     * feign 多个参数传值
     * @param name
     * @param pass
     * @return
     */
    @RequestMapping("/getNameMore")
    public String getNameMore(@RequestParam("name") String name, @RequestParam(value="pass") String pass){
          return "feign传递多参数的值"+name+pass;
    }


    /**
     * feign 传递 module l类型的值
     * @param user
     * @return
     */
    @RequestMapping("/getUser")
    public String getUser(@RequestBody User user){
            return "feign传递model类型的值"+user.getName()+user.getPass();
    }

}



作者:滔滔逐浪
链接:https://www.jianshu.com/p/4b0c58bbf284

在Spring Cloud中使用Feign进行服务间通信是一种声明式的HTTP客户端调用方式,开发者可以像调用本地方法一样调用远程服务,大大简化了服务之间的通信代码的编写。Feign与Spring Cloud的其他组件集成良好,例如与服务注册中心(如Eureka)、断路器(如Hystrix)等的集成,使得微服务架构的搭建更加便捷[^1]。 ### Feign的核心概念 Feign是一种声明式的HTTP客户端,其核心思想是通过注解定义远程调用的API接口,并将其转换为HTTP请求形式。Feign还支持Spring MVC注解,简化了HTTP请求的构建过程。此外,Feign整合了Ribbon提供客户端的负载均衡实现,以及Hystrix服务熔断器,增强了服务调用的可靠性[^3]。 ### Feign的基本使用使用Feign,开发者需要定义一个接口,并通过注解声明需要调用的服务方法。Feign会根据接口定义和注解生成HTTP请求,将远程服务的响应结果解码成Java Bean返回给调用者。以下是一个简单的Feign服务调用示例: #### 1. 服务提供者 假设有一个服务提供者,提供了一个简单的REST接口用于返回用户信息: ```java @RestController @RequestMapping("/user") public class UserController { @GetMapping("/{id}") public User getUserById(@PathVariable Long id) { return new User(id, "John Doe"); } } ``` #### 2. 服务消费者 在服务消费者中,定义一个Feign客户端接口,声明需要调用的服务方法: ```java @FeignClient(name = "user-service") public interface UserClient { @GetMapping("/user/{id}") User getUserById(@PathVariable("id") Long id); } ``` #### 3. 启用Feign客户端 在Spring Boot应用的主类中,启用Feign客户端支持: ```java @SpringBootApplication @EnableFeignClients public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` #### 4. 使用Feign客户端 在业务逻辑中注入并使用Feign客户端: ```java @Service public class UserService { private final UserClient userClient; public UserService(UserClient userClient) { this.userClient = userClient; } public User getUserById(Long id) { return userClient.getUserById(id); } } ``` ### Feign的高级功能 Feign还支持一系列高级功能,包括日志配置、解码器、拦截器等,开发者可以根据需求对Feign的行为进行定制化。例如,通过配置Feign的日志级别,可以查看详细的HTTP请求和响应信息: ```java @Configuration public class FeignConfig { @Bean Logger.Level feignLoggerLevel() { return Logger.Level.FULL; } } ``` ### 相关问题 Feign与Ribbon的集成使得服务调用具备了负载均衡能力,同Hystrix的支持为服务调用提供了熔断机制,进一步增强了系统的健壮性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值