qt.tlsbackend.ossl: Failed to load libssl/libcrypto.

我的环境是windows,QT6.3.2(msvc2019_64/mingw_64)

出错原因

QT没有正确加载OpenSSL。

解决过程

1、确保安装的有openssl。

文章结尾有个注意,是其他方式安装过openssl,环境变量有,但是QT找不到的问题。

在我这次使用的时候,没有单独去安装OpenSSL,因为我在QT的下面路径找到了需要的库。

我不太确定这是我安装QT时特意选的,还是默认就有,反正如果没有,尽量到官网下载,因为结尾的注意会讨论这个事。

2、解决方法

方法一:

把上述文件复制到你所使用版本QT的下面路径下:

注意你使用的是mingw_64就往这复制,使用的msvc2019就往对应的文件夹复制

复制完应该就可以用了。

方法二:

将上面找的的文件所在地址添加到环境变量

注意添加完,需要确定环境变量,然后重新启动QTcreator才能生效。

不要急,等一下下,不行再重启试试。

我下面是删掉环境变量的实验结果,(实验代码在下面),左边是打开马上运行的结果,他找到了!!!但是环境变量被我删了!!!不应该找到啊!!!

我差点以为写这么半天做了无用功,结果我看了一下他项目里用到的环境变量,并没有啊,然后我又运行了一下, 他又没找到,而且自己单开了一个输出页面,不理解。反正结果是对的。

验证是否成功

复制代码
#include <QSslSocket>
#include <QDebug>

int main() {
    qDebug() << "OpenSSL supported:" << QSslSocket::supportsSsl();
    qDebug() << "OpenSSL runtime version:" << QSslSocket::sslLibraryVersionString();
    return 0;
}

直接把上面这段放在main.cpp运行。

注意上述结果虽然写了个true,但是没成功调用OpenSSL,而是调用Channel。我这个true是因为写教程的时候环境改了又改,有点混乱了,如果没有使用什么办法的话,它可能显示false,不影响,反正后面显示的实际使用了Secure Channel, Windows。

Qt 默认优先使用 OpenSSL 来处理 HTTPS 请求。如果无法加载 OpenSSL 的动态库(libssl.dll 和 libcrypto.dll),Qt 会尝试使用其他可用的 TLS 后端(如 Windows 的 SChannel 或 macOS 的 SecureTransport)。

其实如果你不介意使用 Windows 的 SChannel 而不是 OpenSSL,并且程序运行正常,可以选择忽略这条警告信息。

我一开始就是不懂,看起来好像功能实现了,但是它在最开始报了这个警告。就是下面这样。

这就是使用SChannel实现了功能。

如果环境弄成功了,应该是下面的结果:

如果上面的方法没有成功,可能是OpenSSL版本问题,可能与QT不对应,自行百度下。

遇到的一个问题

注意:遇到另一个问题就是我最初发现我的电脑里有OpenSSL,并且添加了环境变量,但是无法使用。

在终端输入命令openssl version获得的openssl不一定可用

上述是我在我电脑里找到的,一开始以为有,能够用命令搜到其实应该是添加了环境变量,我一开始没反应过来,又手动添加了一次,发现不能用。根据文件夹名称可以看到,我是安装strawberry的时候带的,我其实都忘了这个strawberry拿来干啥的了。。。

一开始以为是因为他是.exe执行文件所以不行,但是打开目录发现他有那两个动态库:

而且都是x64的,注意这个也是个点,没有x64就代表是32位的,至于是不是所有版本QT都是用64位的,这需要自己去找了。

一开始我以为通过其他东西附带的这种方式下载的不全,用不了。

后面我思考了一下,应该是版本不行的问题。

真正要注意的来了:

想着送佛送到西,为了验证是不是版本问题,结果整出很多事。

结论:

1、QTcreator里面找到的高版本就按前面说的来,就没问题,理论官网下的应该也没问题。

2、重点是后面分析的strawberry问题,strawberry里的那2个库文件名字中带了2横杠,把strawberry里的2个文件的最后的2个横杠删掉复制到方法一的位置(例:F:\Qt\6.3.2\mingw_64\bin),注意strawberry文件里的文件名不变。或者是strawberry文件里那2个文件删掉2横杆,复制给方法一里面的不删。反正就是strawberry文件夹里和(例:F:\Qt\6.3.2\mingw_64\bin)里,一个带横杠一个不带,但必须2个都有,很怪,但确实是这样。反正这样弄完他确实是strawberry里面的版本。。。。。。要用这个方法的,就是电脑里其他什么东西下载过openssl的,建议选择在(例:F:\Qt\6.3.2\xxxx_64\bin)里面修改文件名,原路径不动,避免影响其他程序。还有试了这个复制文件的方法与环境变量无关。

3、就是建议QT里面没有openssl库的,去官网重新下吧,虽然我无意找到了其他地方存在openssl库,然后能让QT使用的方法,但是会改文件名,不太清楚会对原本的程序有什么影响,所以我最后就没去动strawberry,还是使用的QT里面找到的版本。

下面是部分心路历程,本来是要写过程的,结果越来越匪夷所思,懒得写了。

上面不是提到我安strawberry里面顺带安装了openssl吗,但是不能用。我把他们复制到QT里去试一下,不用环境变量的方式。还好我为了严谨,把VC和GW文件夹都试一遍,VC复制完,运行不成功,结果复制到GW的时候我复制错地方,复制到QTcreator下面,就是找到能用open SSL动态库的地方,我一下警觉,他没有给我报重复文件的提示,我再想是不是之前被我剪切了,结果没有,然后我仔细对比了文件名,,,strawberry里的多了2个横杠,因为安装straw时他自己添加过环境,所以我把名字里的横杠去掉后,直接运行验证代码:

到这以为成功了,结束了,结果才是诡异的开始,太复杂,懒得写了。。。

相关推荐
TNTLWT44 分钟前
程序生成随机数
开发语言
ansenXia1 小时前
CentOS系统中排查进程异常终止的日志
开发语言·python
ᖰ・◡・ᖳ2 小时前
前端之勇闯DOM关
开发语言·前端·javascript·学习·html
双叶8362 小时前
(51单片机)LCD显示温度(DS18B20教程)(LCD1602教程)(延时函数教程)(单总线教程)
c语言·开发语言·单片机·嵌入式硬件·mongodb·51单片机·nosql
666HZ6662 小时前
Web前端开发技术——HTML5、CSS3、JavaScript
前端·css3·html5
好蛋编程2 小时前
【c语言】指针进阶
c语言·开发语言
二猛子2 小时前
Qt-托盘的实现
开发语言·qt
用户878623683782 小时前
QT6和QT5,使用player设定播放视频的注意点!
qt
未来之窗软件服务3 小时前
眼镜眨巴眨巴-一步几个脚印从头设计数字生命——仙盟创梦IDE
开发语言·ide·人工智能·php·仙盟创梦ide
刚入坑的新人编程3 小时前
C++继承(最详细)
开发语言·c++