Qt6.7.2中使用OpenSSL的坑

最近编写Qt Quick项目,使用Qt6.7.2版本,CMAKE编译,开始QtCreator运行代码都没有问题,访问https也正常,但打出安装包后一试,发现https访问不了,尴尬!!

查看了相关日志发现:

WARG 16:50:02.340 qt.network.ssl: No functional TLS backend was found

WARG 16:50:02.340 qt.network.ssl: No TLS backend is available

WARG 16:50:02.340 qt.network.ssl: No functional TLS backend was found

WARG 16:50:02.340 qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed

......

WARG 16:50:02.604 qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed

网上搜索,发现一大堆人都说是openssl库缺少,安装openssl对应库,然后拷贝两个文件;

libcrypto-3-x64.dll 与 libssl-3-x64.dll对运行目录下即可。具体过程网上一堆,比如用

QSslSocket::sslLibraryBuildVersionString();

查看当前QT版本支持的openssl库的版本号,用

QSslSocket::supportsSsl(); 查看系统是否支持ssl,

一开始,在win11上,qt6.7.2调用以上两个接口,返回的是:

secure channel (ntddi: 0xa00000c) 和 true,

这时你自己随意下载个openssl的版本,安装一下,比如openssl3.3.2 ,安装后再去调用,则会返回:"OpenSSL 3.0.7 1 Nov 2022" ---- true

本以后是自己用的openssl版本不一直,导致即使用了两个库libcrypto、libssl也无法访问https,无奈自己又下载opensll3.0.7的源码,编译,一堆操作。但最终,并无鸟用......

奇怪的项目是在QtCreator运行下,判断openssl的两个接口有返回:"OpenSSL 3.0.7 1 Nov 2022" ---- true,但单独点击运行程序运行却没有输出,supportsSsl()返回false;

......其实很简单,这是QT6的一个bug,

Qt 6.2.0 - beta 3 - Qt Network: qt.network.ssl: No functional TLS backend was found | Qt Forum

某些Qt库未拷贝到程序运行目录而已,哪些库呢?就是Qt安装目录下对应的tls下的三个库:

C:\Qt\6.7.2\msvc2019_64\plugins\tls

尤其是qopensslbackend.dll (只要有它就可以访问https了)

所以解决方案就是:

将tls这个目录拷贝到运行程序的目录之下即可。

201

手机版

相关推荐
白云偷星子4 分钟前
云原生笔记6
linux·运维·笔记·mysql·云原生
玖剹5 分钟前
gitee在Linux下的使用
linux·运维·gitee
路由侠内网穿透.6 分钟前
本地部署中间件系统 JBoss 并实现外部访问
运维·服务器·网络·网络协议·中间件
领小6 分钟前
VS2022 MFC对话框应用OLE读写操作excel
c++·excel·mfc
白云偷星子6 分钟前
云原生笔记5
linux·运维·笔记·云原生·tomcat
艾莉丝努力练剑8 分钟前
【QT】常用控件(一):初识控件,熟悉QWidget
android·linux·数据库·qt·学习·mysql·qt5
大母猴啃编程12 分钟前
Socket编程UDP
linux·网络·c++·网络协议·udp
是垚不是土15 分钟前
ClaudeCode×Elasticsearch:服务日志查询的 AI 化落地实践
大数据·运维·人工智能·elasticsearch·云计算·jenkins
我是苏苏16 分钟前
Web开发:自动化部署!在Windows系统上安装和使用Jenkins!
运维·自动化·jenkins
2501_9159184117 分钟前
iOS App HTTPS 抓包工具,代理抓包和数据线直连 iPhone 抓包的流程
android·ios·小程序·https·uni-app·iphone·webview