提示错误: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有关,