Spring Boot项目基于Spring Cloud Feign调用第三方外部接口

一、添加maven依赖

(1)添加SpringCloud依赖

<properties>
    <spring-cloud.version>Greenwich.SR1</spring-cloud.version>
</properties>

(2)添加dependencyManagement相关依赖控制Spring Cloud的版本

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

(3)添加openfeign的依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

二、配置config类

import feign.Feign;
import okhttp3.ConnectionPool;
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.context.annotation.Bean;
import org.springframework.cloud.openfeign.FeignAutoConfiguration;
import org.springframework.context.annotation.Configuration;

import java.util.concurrent.TimeUnit;

@Configuration
@ConditionalOnClass(Feign.class)
@AutoConfigureBefore(FeignAutoConfiguration.class)
public class FeignConfig {

    @Bean
    public okhttp3.OkHttpClient okHttpClient(){
        return new okhttp3.OkHttpClient.Builder()
                .readTimeout(60, TimeUnit.SECONDS)
                .connectTimeout(60, TimeUnit.SECONDS)
                .writeTimeout(120, TimeUnit.SECONDS)
                .connectionPool(new ConnectionPool())
                .build();
    }
}

三、主类添加注解

@EnableFeignClients

四、编写feign调用接口

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;

@FeignClient(name = "testfeignSerive", url = "http://ip:port/")
public interface FeignService {

    @RequestMapping(value = "testmethod",method = RequestMethod.POST)
    String getMaillist(@RequestParam(value = "t") String t);

	//文件上传接口传参得用@RequestPart,并加上consumes = MediaType.MULTIPART_FORM_DATA_VALUE
    @PostMapping(value = "service", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
    String upload(@RequestPart(value = "file")MultipartFile file);
    //post方式application/json
	 @RequestMapping(value = "/service", method = RequestMethod.POST,consumes = "application/json")
    String send(@RequestParam(value = "t") String t,@RequestParam("json") String json);
}

五、调用时,直接在controller中,注入该接口即可

@Autowired
    private FeignService feignClientProxy;
String obj = feignClientProxy.getMaillist(t);

程序员改变世界,每天进步一点点,立志不做一个单纯的CV程序员!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值