根据url获取图片资源,设置认证

根据url获取图片资源是碰到问题

PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to fin

但是在浏览器可以正常获取
解决方法

private void writeUrlToFile(String pictureUrl, File outPut) throws Exception {
        //new一个URL对象
        //String encode = URLEncoder.encode(pictureUrl,"utf-8");
        URL url = new URL(pictureUrl);
        // 使用UnsafeTrustManager创建SSLContext
        SSLContext sc = SSLContext.getInstance("TLS");
        sc.init(null, new TrustManager[]{new UnsafeTrustManager()}, new SecureRandom());
        // 使用自定义的SSLContext创建SSLSocketFactory
        SSLSocketFactory ssf = sc.getSocketFactory();
        // 使用SSLSocketFactory创建HttpsURLConnection
        HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
        conn.setSSLSocketFactory(ssf);
        //设置请求方式为"GET"
        conn.setRequestMethod("GET");
        //超时响应时间为5秒
        conn.setConnectTimeout(5 * 1000);
        //通过输入流获取图片数据
        InputStream inStream = conn.getInputStream();
        //得到图片的二进制数据,以二进制封装得到数据,具有通用性
        byte[] data = readInputStream(inStream);
        //new一个文件对象用来保存图片,默认保存当前工程根目录
        //创建输出流
        FileOutputStream outStream = new FileOutputStream(outPut);
        //写入数据
        outStream.write(data);
        //关闭输出流
        outStream.close();
    }

设置无认证的方式

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

public class UnsafeTrustManager 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];
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值