Feign-跳过SSL验证的方案

本文介绍在Feign调用接口时遇到SSL证书过期问题的解决方案,通过自定义SSLContext和TrustManager实现跳过验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

做一个项目的时候,需要调用https的接口,但是对方的ssl证书已经过期,而Feign默认会进行SSL认证,导致接口调用有点问题。当不跳过SSL验证的时候,Feign就会报错:

{
  "code": "1",
  "message": "sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target executing POST https://jxhr.jxsfybjyy.cn/switch/services/jxfy/InteractiveKiosk/DoBusiness",
  "data": null
}

网上的解决方案

写个配置类

@Component
@Import(FeignClientsConfiguration.class)
@Slf4j
public class ReqHosInner {
    private DynamicURLFeignClient dynamicURLFeignClient;

    @Autowired
    public ReqHosInner(Decoder decoder, Encoder encoder) {
        dynamicURLFeignClient = Feign.builder()
                .encoder(encoder)
                .decoder(decoder)
                .client(getFeignClient())
                .target(Target.EmptyTarget.create(DynamicURLFeignClient.class));
    }

    private Client getFeignClient() {
        try {
            SSLContext ctx = SSLContext.getInstance("SSL");
            X509TrustManager tm = new X509TrustManager() {
                @Override
                public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
                }

                @Override
                public void checkServerTrusted(X509Certificate[] chain,String authType) throws CertificateException {
                }

                @Override
                public X509Certificate[] getAcceptedIssuers() {
                    return null;
                }
            };
            ctx.init(null, new TrustManager[]{tm}, null);
            return new Client.Default(ctx.getSocketFactory(), (hostname, session) -> true);
        } catch (Exception e) {
            return null;
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值