POST请求https遇到unable to find valid certification path to requested target

完整异常信息为:

javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

问题出现原因是安全证书不信任。

我选择的方法是,发送请求的时候对带https的请求都选择信任

使用okhttp发送post请求pom如下:

<dependency>
    <groupId>com.squareup.okhttp3</groupId>
    <artifactId>okhttp</artifactId>
    <version>3.6.0</version>
</dependency>

代码如下:

public static JSONObject post(String url, HashMap<String, String> paramsMap) {
    Map<String, String> map = new HashMap<>();
    //设置对所有https证书信任
    TrustAllManager trustAllManager = new TrustAllManager();
    OkHttpClient.Builder okHttpClientaBuilder = new OkHttpClient.Builder().sslSocketFactory(createTrustAllSSLFactory(trustAllManager), trustAllManager);

    //获得client
    OkHttpClient okHttpClient = okHttpClientaBuilder.build();

    FormBody.Builder formBodyBuilder = new FormBody.Builder();
    Set<String> keySet = paramsMap.keySet();
    for (String key : keySet) {
        String value = paramsMap.get(key);
        formBodyBuilder.add(key, value);
    }
    FormBody formBody = formBodyBuilder.build();
    Request request = new Request
            .Builder()
            .post(formBody)
            .url(url)
            .build();
    JSONObject jason = null;
    try {
        Response response = okHttpClient.newCall(request).execute();


        if (response.code() == 201) {
            map.put("message", "success");
            map.put("status_code", "201");
            jason = JSONObject.parseObject(JSONObject.toJSON(map).toString());
        } else {
            jason = JSONObject.parseObject(response.body().string());
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
    return jason;
}

 

protected static SSLSocketFactory createTrustAllSSLFactory(TrustAllManager trustAllManager) {
    SSLSocketFactory ssfFactory = null;
    try {
        SSLContext sc = SSLContext.getInstance("TLS");
        sc.init(null, new TrustManager[]{trustAllManager}, new SecureRandom());
        ssfFactory = sc.getSocketFactory();
    } catch (Exception ignored) {
        ignored.printStackTrace();
    }

    return ssfFactory;
}
package com.otcbi.util.regwidutils;

import javax.net.ssl.X509TrustManager;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;

public class TrustAllManager implements 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 new X509Certificate[0];
    }
}

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值