Próbuję utworzyć przykładowe projekty Java, które łączą się z samopodpisanym serwerem HTTPS. Nie mogę sprawić, że Java przestanie próbować sprawdzać poprawność certyfikatu. Nie chcę ufać temu certyfikatowi, chcę po prostu zignorować wszystkie walidacje certyfikatów; ten serwer znajduje się w mojej sieci i chcę mieć możliwość uruchamiania niektórych aplikacji testowych bez obawy, czy certyfikat jest ważny.Sprawdzanie poprawności certyfikatu Java ignore
java -Dcom.sun.net.ssl.checkRevocation=false HelloWorld
org.apache.axis2.AxisFault: Connection has been shutdown: 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
-Dcom.sun.net.ssl.checkRevocation = false nie pomogło. Próbowałem też dodając następujący kod:
public static void DisableCertificateValidation() {
TrustManager[] trustAllCerts = new TrustManager[]{
new X509TrustManager() {
public X509Certificate[] getAcceptedIssuers() { return null; }
public void checkClientTrusted(X509Certificate[] certs, String authType) { }
public void checkServerTrusted(X509Certificate[] certs, String authType) { }
}
};
try {
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, new java.security.SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
} catch (Exception e) {
}
}
Ale nadal mam ten sam problem. Co tu się dzieje?
Czy udało Ci się zignorować certyfikat z osią2? Josip – cromorrissey