在日常开发中,经常会用到请求第三方接口的方式,在C#中使用的是HttpClient的方式发起请求,如果在Java中,则需要使用FeignClient的方式来进行请求接口。

本次主要以两种方式使用Feign进行接口访问请求

引用Meven包:Maven: org.springframework.cloud:spring-cloud-openfeign-core:3.0.3

pom.xml文件中添加引用:

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

一、直接请求第三方接口。此方式请求需要自定义传入实体和返回实体。

application.properties文件中添加配置:

# 统一日志记录接口API
ms.service.adminlog.name=ms-service-adminlog
ms.service.adminlog.url=http://service-adminlog.test.com

FeignClient请求具体代码:

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.springframework.cloud.openfeign.FallbackFactory;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.PostMapping;

/**
 * 后台日志记录 API Client
 *
 * @author suxuelian
 */
@FeignClient(value = "${ms.service.adminlog.name}-log", url = "${ms.service.adminlog.url}"
        , fallbackFactory = AdminOperationLogApiClientFallbackFactory.class)
public interface AdminOperationLogApiClient  {

    @PostMapping(value = "/api/adminlog/SaveOperationLog")
    ApiResult<String> saveAdminOperationLog(SaveOperationLogReqDTO reqDTO);
}


@Component
class AdminOperationLogApiClientFallbackFactory implements FallbackFactory<AdminOperationLogApiClient> {

    private static final AdminOperationLogApiClient ADMIN_OPERATION_LOG_API_CLIENT = new AdminOperationLogApiClient() {

        @Override
        public ApiResult<String> saveAdminOperationLog(SaveOperationLogReqDTO reqDTO) {
            return null;
        }
    };

    private final Logger logger = LogManager.getLogger(AdminOperationLogApiClientFallbackFactory.class);

    @Override
    public AdminOperationLogApiClient create(Throwable cause) {
        LogTrace groupIdLogTrace = new LogTrace( "", "AdminOperationLogApiClientFallbackFactory");
        groupIdLogTrace.setError(cause);
        return ADMIN_OPERATION_LOG_API_CLIENT;
    }
}

/**
 * 新增日志记录 Request DTO
 *
 * @author suxuelian
 */
@Data
@Accessors(chain = true)
public class SaveOperationLogReqDTO {

    /**
     * 统一用户中心ID
     */
    @ApiModelProperty("统一用户中心ID")
    private  Integer centerUserId;


    /**
     * 新内容(当操作类型为编辑、删除、审核时需要填写)
     */
    @ApiModelProperty("新内容(当操作类型为编辑、删除、审核时需要填写)")
    private  String newContent;

    /**
     * 老内容(当操作类型为编辑、删除、审核时需要填写)
     */
    @ApiModelProperty("老内容(当操作类型为编辑、删除、审核时需要填写)")
    private  String oldContent;


    /**
     * 操作类型 (1:查看 2:添加 4:编辑 8:删除 16:审核 32:搜索 64:特权)
     */
    @ApiModelProperty("操作类型 (1:查看 2:添加 4:编辑 8:删除 16:审核 32:搜索 64:特权)")
    private  Integer powerType;

    /**

}

在使用过程中,如果发现了缺少Meven,请自行引用。

二、第二种方式是引用包的方式请求,虽然同样需要配置请求地址,但是不用重复在项目中编写请求参数和返回参数,从一定程度上减轻了工作量。

首先需要在pom.xml文件中引用需要使用的项目及对应的包,大概引用方式如下:

<properties>
 <test_adminlog.api.version>1.0.0</test_adminlog.api.version>
 </properties>

<dependencyManagement>
        <dependencies>

          <dependency>
                <groupId>com.myapi</groupId>
                <artifactId>service-admin-log-api-contract</artifactId>
                <version>${test_adminlog.api.version}</version>
            </dependency>
        </dependencies>
</dependencyManagement>

application.properties文件中依然要添加接口地址,配置方式如方法一中的配置方式

具体代码编写方式如下:

import com.hualv.bigdataframework.common.pojo.ApiResult;
import com.hualv.bigdataframework.common.utils.log.LogTrace;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.springframework.cloud.openfeign.FallbackFactory;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import javax.validation.Valid;
import 这是需要引用刚刚在pom文件中设置的项目代码命名空间


/**
 * 订单投诉 API Client
 *
 * @author suxuelian
 */
@FeignClient(value = "${ms.service.adminlog.name}", url = "${ms.service.adminlog.url}"
        , fallbackFactory = OrderComplaintApiClientFallbackFactory.class, path = "/api")
public interface OrderComplaintApiClient extends OrderComplaintApi {

//OrderComplaintApi 这里的此类就是需要引用的包中的接口类
}

@Component
class OrderComplaintApiClientFallbackFactory implements FallbackFactory<OrderComplaintApi> {

    private static final OrderComplaintApi ORDER_API_CLIENT_FALLBACK_FACTORY = new OrderComplaintApi() {

        @Override
        public ApiResult<String> insertComplaint(@Valid ComplaintAddReqDto complaintAddReqDto) {
            return null;
        }

    };


    private final Logger logger = LogManager.getLogger(OrderComplaintApiClientFallbackFactory.class);

    @Override
    public OrderComplaintApi create(Throwable cause) {
        LogTrace groupIdLogTrace = new LogTrace( "", "OrderComplaintApiClientFallbackFactory");
        groupIdLogTrace.setError(cause);
        logger.info(LogTrace.BIZ_TRACE_MARKER, groupIdLogTrace);
        return ORDER_API_CLIENT_FALLBACK_FACTORY;
    }
}

以上是在开发中使用过FeignClient的两种使用方式,变标不变本,一般情况,使用第一种方式即可,第二种在协同开发时需要注意信息同步的及时性,否则容易经常发生报错的情况。

欢迎各位大佬指出其中的不足,在开发中的日常积累,或许不够完美,希望能帮助到需要的码友。

精选文案|一点一点去靠近梦想,不抱侥幸的奢望,用踏实浇灌,用努力证明,你可以!