是否有任何命令行标志可以启用Java以允许过期证书?
目前,由于证书已过期,我会收到以下异常。
Caused by: java.security.cert.CertificateExpiredException: NotAfter: {PAST DATETIME}
at sun.security.x509.CertificateValidity.valid(CertificateValidity.java:274)
at sun.security.x509.X509CertImpl.checkValidity(X509CertImpl.java:629)
at sun.security.x509.X509CertImpl.checkValidity(X509CertImpl.java:602)
at org.apache.ws.security.validate.SignatureTrustValidator.validateCertificates(SignatureTrustValidator.java:103)
我尝试了以下命令行标志,但它不会忽略证书过期检查。
-Dcom.sun.net.ssl.checkRevocation=false
我们的应用程序在Tomcat下运行,路径为/myapplication
。因此,我创建了另一个应用程序/ignorecertificate
并部署在同一Tomcat的webapp文件夹中。根据这个问题的接受答案,我在/ignoreexpired
应用程序的启动时运行以下代码。
// Create a trust manager that does not validate certificate chains
TrustManager[] trustAllCerts = new TrustManager[]{
new X509TrustManager() {
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return null;
}
public void checkClientTrusted(
java.security.cert.X509Certificate[] certs, String authType) {
}
public void checkServerTrusted(
java.security.cert.X509Certificate[] certs, String authType) {
}
}
};
// Install the all-trusting trust manager
try {
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, new java.security.SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
} catch (Exception e) {
e.printStackTrace();
}
由于两个应用程序都部署在同一个Tomcat中,我希望/myapplication
忽略证书过期检查/异常(因为两个应用程序共享相同的Java实例)。但是它仍然不能正常工作。 我在另一个应用程序(/ignoreexpired
)中运行此忽略代码,因为我不想对我的当前应用程序(/myapplication
)进行任何更改。