Qt服务器程序打包后TLS初始化失败

提示错误:qt.network.ssl: QSslSocket::startServerEncryption: TLS initialization failed

在这里插入图片描述
出问题时的环境: 服务器部署在新windows10,什么环境都莫得。
分析原因: 打眼一看就是openssl没安装出问题的。

直接解决方法:新windows10安装Openssl即可,或者将1.1.1.k 版本的OpenSSL库libcrypto-1_1-x64.dll和libssl-1_1-x64.dll放到程序运行目录下**
http://slproweb.com/products/Win32OpenSSL.html

走了一些弯路情况

1. Qt在线安装时可能有人跟我一样安装过Openssl,如图:
在这里插入图片描述
这个库拷到新Windows10上而且配了环境变量,错误依然还在。注意一下的 两个库版本:1.1.1.j
在这里插入图片描述

**2.**取消前面的Qt自带openssl库和环境变量,尝试进行上述的安装版OpenssL到新window10上。
结果是成功的。
在这里插入图片描述
提示是Copy OpenSSL DLL to 系统文件里面。注意一下安装后这 两个库版本:1.1.1.K
在这里插入图片描述

分析上述两个库版本不同影响Qt程序在新Windows上运行的原因:

源代码合适位置添加如下调试信息且重新部署:(用qdebug即可,xdebug是自己封装的调试类)
其中supportsSsl()方法在源码中是抛出此错误的地方。在这里插入图片描述

重新部署后取消所有OpenSsl的环境。程序运行如下图
在这里插入图片描述

  • 新环境不支持SSL
  • 旧环境构建项目时的OpenSSL库版本是 1.1.1g
  • 新环境运行时找不到OpenSSL库

1. 将1.1.1.j 版本的libcrypto-1_1-x64.dll和libssl-1_1-x64.dll放到程序运行目录下
不支持OpenSSl,运行时还是找不到OpenSSl库
在这里插入图片描述
2. 将1.1.1.k 版本的libcrypto-1_1-x64.dll和libssl-1_1-x64.dll放到程序运行目录下**
成功支持OpenSSL,且找到了本地OpenSSL库。TLS初始化失败被解决掉了。
在这里插入图片描述

总结:服务器端TLS初始化失败是没有openssl库在当前新环境中。要么将两个库打包到程序目录,要么在新环境重新装OpenSSL。而且库的版本也会影响TLS初始化能否成功。
可能和构建时的版本
1.1.1g
有关,


版权声明:本文为YanWenCheng_原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。