收到致命警报:SSLHandshakeException导致握手失败
||
授权SSL连接有问题。我已经创建了Struts Action,它使用客户端授权的SSL证书连接到外部服务器。在我的操作中,我尝试将一些数据发送到银行服务器,但是没有任何运气,因为由于服务器的原因,我出现以下错误:
error: javax.net.ssl.SSLHandshakeException: Received fatal alert: handshake_failure
我的Action类中的My Method将数据发送到服务器
//Getting external IP from host
URL whatismyip = new URL(\"http://automation.whatismyip.com/n09230945.asp\");
BufferedReader inIP = new BufferedReader(new InputStreamReader(whatismyip.openStream()));
String IPStr = inIP.readLine(); //IP as a String
Merchant merchant;
System.out.println(\"amount: \" + amount + \", currency: \" + currency + \", clientIp: \" + IPStr + \", description: \" + description);
try {
merchant = new Merchant(context.getRealPath(\"/\") + \"merchant.properties\");
} catch (ConfigurationException e) {
Logger.getLogger(HomeAction.class.getName()).log(Level.INFO, \"message\", e);
System.err.println(\"error: \" + e.getMessage());
return ERROR;
}
String result = merchant.sendTransData(amount, currency, IPStr, description);
System.out.println(\"result: \" + result);
return SUCCESS;
我的merchant.properties文件:
bank.server.url=https://-servernameandport-/
https.cipher=-cipher-
keystore.file=-key-.jks
keystore.type=JKS
keystore.password=-password-
ecomm.server.version=2.0
encoding.source=UTF-8
encoding.native=UTF-8
我第一次以为这是证书问题,我将其从.pfx转换为.jks,但我遇到了相同的错误,没有任何更改。
没有找到相关结果
已邀请:
17 个回复
夏瓤跋棘
类,并找出用于建立连接的类/库。 将服务器的证书颁发机构CA添加到此信任存储区应该可以解决此问题。您可以在有关为此目的获取工具的相关问题上参考我的回答,但是Java keytool实用程序足以满足此目的。 警告:信任库实质上是您信任的所有CA的列表。如果您输入的证书不属于您不信任的CA,则如果私钥可用,则可以解密到具有由该实体颁发的证书的站点的SSL / TLS连接。 更新#2:了解JSSE跟踪的输出 JVM所使用的密钥库和信任库通常在一开始就列出,如下所示:
如果使用了错误的信任库,则需要将服务器的证书重新导入到正确的证书中,或者将服务器重新配置为使用列出的证书(如果您有多个JVM,并且所有JVM都不建议使用,则不建议使用用于不同的需求)。 如果要验证信任证书列表中是否包含必需的证书,则有一个相同的部分,其开头为:
您需要查找服务器的CA是否为主题。 握手过程中将有几个显着的条目(您需要了解SSL才能详细了解它们,但是出于调试当前问题的目的,知道在ServerHello中通常报告出handshake_failure就足够了。 1. ClientHello 初始化连接时,将报告一系列条目。客户端在SSL / TLS连接设置中发送的第一条消息是ClientHello消息,通常在日志中报告为:
请注意使用的密码套件。这可能必须与商人。属性文件中的条目一致,因为银行的库可能采用相同的约定。如果使用的约定不同,则无需担心,因为如果密码套件不兼容,ServerHello会声明。 2. ServerHello 服务器以ServerHello响应,这将指示连接设置是否可以继续。日志中的条目通常为以下类型:
注意它选择的密码套件;这是服务器和客户端均可使用的最佳套件。如果出现错误,通常不指定密码套件。服务器的证书(以及可选的整个链)是由服务器发送的,可以在以下条目中找到:
如果证书验证成功,您将找到类似于以下内容的条目:
上述步骤之一将不会成功,从而导致handshake_failure,因为握手通常在此阶段完成(不是真的,但是握手的后续阶段通常不会导致握手失败)。您需要弄清楚哪个步骤失败了,并发布相应的消息作为问题的更新(除非您已经理解了该消息,并且知道如何解决)。
熊融炭臀陛
桑娠贯涤
4.客户证书链 这是客户端发送到服务器的证书。
如果链中没有证书,并且服务器需要证书,那么您将在此处收到握手错误。可能的原因是找不到证书的路径。 5.证书验证 客户端要求服务器验证证书
仅当您发送证书时,此步骤才会发生。 6.完成 服务器将以验证响应进行响应
癸痊醒
和
方法启用这些密码套件。参见JDK-8077109(非公开)。 如果您的服务器强烈希望使用此密码(或仅使用此密码),则这会在Java上触发“ trigger19”。 您可以测试连接到启用RC4密码的服务器的方式(首先,尝试不带
参数,以查看是否触发了
,然后设置
:
1-https://www.java.com/en/download/faq/release_changes.xml
炬卤遁蝎变
jvm将以此顺序协商。具有最新更新的服务器将执行1.2,有问题的服务器将降至v1,并且可与Java 7中的类似v1一起使用。
埠仙俊
孝箱捆讨
和
,并确认证书本身不存在任何问题,则可能需要增强安全算法。 如Vineet的回答中所述,收到此错误的一个可能原因是由于使用了不兼容的密码套件。通过使用Java密码学扩展(JCE)中提供的更新了JDK的
文件夹中的
和
jars,我能够成功完成握手。
梦话快家腹
马口
您将获得许多详细信息,关键信息如下:
2)配置您的http客户端,例如,在OkHttp客户端的情况下:
这将得到我们想要的。
扫窟
在成功完成
之后但未开始数据流之前,with19 connection连接失败。 没有明确的错误消息可以确定问题所在,该错误看起来像
我通过尝试使用和不使用\“
\”选项来隔离问题
瓜唱鬼
容淑阔九
咳累录酬
宦哨抹存胳
磨标烫徽啪
盛虱
徐百晴墓斜
在Java上启用SSL握手调试。 如果您在以下步骤中运行时在密码中发现
,则通过
在服务器上安装ssldump或通过此链接从源代码进行编译。 在服务器上,
检查有关失败的真正原因的日志。 ssldump日志无法正常握手的示例:
ssldump日志成功握手的示例
Java日志无法正常运行的示例