访问信创系统的服务器报错Received fatal alert: handshake_failure

1、问题

某业务需要获取A服务器资源,在A服务器未迁移系统时访问正常,迁移为信创系统时,再次访问资源报错Received fatal alert: handshake_failure,用浏览器访问则报:

此服务器的系统为Windows 2012R2,首次分析问题出现的原因,可能是协议的问题。

2、问题出现的原因

  1. 为了排查原因,采用Win11系统作对比,发现Win11系统访问A服务器资源没有问题,打开Internet选项(打开控制面板找到internet选项,打开后点击"高级",见下图)发现Win11系统支持TLS1.2、TLS1.3,而Win2012 R2支持TLS1.0、1.1、1.2。

进一步确定问题出现的原因,采用openssl(官方下载链接),找到对应系统的Light版本,安装后打开openssl prompt。

输入以下命令,验证A服务器是否支持TLS1.2。

复制代码
openssl s_client -connect 域名:端口号 -tls1_2

查看输出结果,其中包含ssl-session表示本次握手的会话信息(采用win11的客户端访问):

复制代码
SSL-Session:
    Protocol  : TLSv1.2 最终协商使用的TLS版本
    Cipher    : ECDHE-RSA-AES256-GCM-SHA384 加密套件:密钥交换算法(ECDHE)
                                                     认证方式(RSA)
                                                     对称加密算法(AES256-GCM)
                                                     摘要算法(SHA384)
    Session-ID: XXX 本次的会话id

采用win server 2012验证,返回了read R block,随后返回了handshake failure。

  1. 在项目中输出当前上下文采用的加密套件

    SSLContext context = SSLContext.getDefault();

    for (String s : context.getSupportedSSLParameters().getCipherSuites()) {
    if (s.contains("ECDHE")) {
    System.out.println(s);
    }
    }

输出后发现没有对方服务器需要的加密套件。

3、解决方法

1、升级jdk的版本;

2、更新系统;

待续。。

相关推荐
江华森18 小时前
操作系统与 Linux 内核实战教程
linux·运维·服务器
旺王雪饼 www18 小时前
localStorage 和 sessionStorage区别与联系
服务器·前端·javascript
xixingzhe218 小时前
AI运维注意点
运维·人工智能
大树8819 小时前
PUE 超 1.35 要多交多少?存量机房液冷改造 3 张算账表
大数据·运维·服务器·人工智能
小此方19 小时前
Re:Linux系统篇(二十八)文件篇·一:理解 Linux 文件基础I/O、Linux 文件操作与系统调用机制
linux·运维·服务器
likerhood19 小时前
Linux 服务器基础资源查看:CPU、GPU、内存、磁盘与一键检测脚本
linux·运维·服务器
极客先躯19 小时前
高级java每日一道面试题-2026年01月19日-实战篇[Docker]-如何配置镜像仓库的垃圾回收 (GC)?
java·运维·docker·容器
AOwhisky19 小时前
学习自测与解析:MySQL 系列第三期与第四期
linux·运维·数据库·学习·mysql·云计算
流浪00119 小时前
Linux系统篇(三):Linux 命令行参数 & 环境变量:程序和系统沟通的底层逻辑
linux·运维·服务器
yyuuuzz20 小时前
AI模型部署中的常见稳定性问题
运维·服务器·网络·数据库·人工智能·云计算·github