根据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];
}
}