Feign-跳过SSL验证的方案

背景

做一个项目的时候,需要调用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;
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值