解决sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
客户端无法信任服务器证书的问题, 忽略掉对服务器的验证
public void test3() throws NoSuchAlgorithmException, KeyManagementException, IOException
{
URL url = new URL("https://ts.com:8443/ttt/sss.html");
HostnameVerifier verifier = new HostnameVerifier()
{
@Override
public boolean verify(String paramString, SSLSession paramSSLSession)
{
return true;
}
};
TrustManager[] trustAllCerts = new TrustManager[1];
TrustManager tm = new miTM();
trustAllCerts[0] = tm;
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, null);
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
HttpsURLConnection.setDefaultHostnameVerifier(verifier);
URLConnection connection = url.openConnection();
BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream(), "utf-8"));
String line = null;
while ((line = reader.readLine()) != null)
{
System.out.println(line);
}
reader.close();
}
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
class miTM implements TrustManager, X509TrustManager
{
public X509Certificate[] getAcceptedIssuers()
{
return null;
}
public boolean isServerTrusted(X509Certificate[] certs)
{
return true;
}
public boolean isClientTrusted(X509Certificate[] certs)
{
return true;
}
public void checkServerTrusted(X509Certificate[] certs, String authType) throws CertificateException
{
return;
}
public void checkClientTrusted(X509Certificate[] certs, String authType) throws CertificateException
{
return;
}
}