使用Windows资源库证书连接WebService时遇到问题。
问题是Windows始终是存储库上的第一个证书,忽略了属性keystoreAlias。我现在喜欢Wath是错的吗?
我在存储库上有3个证书,我想使用第三个证书,但是Windows总是选择第一个。
ks = KeyStore.getInstance("Windows-MY");
try {
ks.load(null, configNFSe.getSenhaCertificadoDigital().toCharArray());
} catch (IOException e) {
throw new Exception("Senha do Certificado Digital esta incorreta ou Certificado inválido.");
}
Enumeration<String> aliasEnum = ks.aliases();
while (aliasEnum.hasMoreElements()) {
String alias = aliasEnum.nextElement();
if (ks.isKeyEntry(alias)) {
String certificado = alias;
X509Certificate certificate = (X509Certificate) ks.getCertificate(alias);
if (certificate.getSubjectDN().toString().equals(configNFSe.getAliasCertificado()) || alias.equals(configNFSe.getAliasCertificado())) {
keyEntry = (KeyStore.PrivateKeyEntry) ks.getEntry(alias, new KeyStore.PasswordProtection(configNFSe.getSenhaCertificadoDigital().toCharArray()));
atualizarSenhaAliasCertificado(certificate);
Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider());
System.setProperty("com.sun.xml.ws.transport.http.client.HttpTransportPipe.dump", "true");
System.setProperty("com.sun.xml.ws.transport.http.HttpAdapter.dump", "true");
System.setProperty("sun.security.ssl.allowUnsafeRenegotiation", "true");
System.setProperty("java.protocol.handler.pkgs", "com.sun.net.ssl.internal.www.protocol");
System.clearProperty("javax.net.ssl.keyStore");
System.clearProperty("javax.net.ssl.keyStorePassword");
System.clearProperty("javax.net.ssl.trustStore");
System.clearProperty("javax.net.ssl.keyStoreAlias");
System.setProperty("javax.net.debug", "ssl");
System.setProperty("javax.net.ssl.keyStoreProvider", "SunMSCAPI");
System.setProperty("javax.net.ssl.keyStoreType", "Windows-MY" );
System.setProperty("javax.net.ssl.keyStore", "cert_jf_p.jks");
System.setProperty("javax.net.ssl.keyStorePassword", "passwordCertificate");
System.setProperty("javax.net.ssl.keyStoreAlias", alias);
System.setProperty("javax.net.ssl.trustStoreType", "JKS");
System.setProperty("javax.net.ssl.trustStore","cert_jf_p.jks");
System.setProperty("javax.net.ssl.trustStorePassword", "changeit");
break;
}
}
}
答案 0 :(得分:0)
Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider());
自2002年以来,这还没有必要。
System.clearProperty("javax.net.ssl.keyStoreAlias");
我没有看到您要设置的属性清除点,但有no such property defined in JSSE。
System.setProperty("java.protocol.handler.pkgs", "com.sun.net.ssl.internal.www.protocol");
自2002年以来,这还没有必要。
System.setProperty("javax.net.ssl.keyStoreAlias", alias);
有no such property defined in JSSE。
另见this question确认。