首页 > 系统相关 >windeployqt.exe的使用与避坑(windows平台)

windeployqt.exe的使用与避坑(windows平台)

时间:2024-08-14 14:16:22浏览次数:17  
标签:exe Qt windows windeployqt 避坑 VS 应用程序 版本

1. 介绍

windeployqt.exe是Qt自带的工具,用于创建应用程序发布包。 简单来说,这个工具可以自动地将某程序依赖的库、资源拷贝到其所在目录,防止程序在其他电脑上运行报找不到库的错误。 这里贴上官方文档:https://doc.qt.io/qt-5/windows-deployment.html

本文适用于Windows + Visual Studio + Qt平台。

2. 原理

windeployqt.exe工作原理很简单,它会到当前的环境变量PATH配置的搜索路径中,查找应用程序所需要的库和资源,拷贝到应用程序目录中。

3. 使用

1、先从开始菜单中打开对应版本的Qt命令行终端界面,如下图:

 

2、命令行中输入

windeployqt.exe 应用程序完整路径

我们知道,Qt项目路径不能包含中文,所以为了保险起见,应用程序路径中不要包含中文。另外,如果应用程序路径中包含空格,需要用双引号将整个路径字符串包裹起来。

回车即可执行发布命令。输出界面如下图所示:

 

进入到应用程序目录可以看到,目录中增加了很多依赖库和数据文件。如下图所示:

大体上的流程只有这两步。 整个发布过程看似比较简单,但是其中还是存在一些坑的。

3.1 坑点一:未使用Qt的命令行终端执行发布命令,导致库版本拷贝错误

下面是直接使用系统cmd命令行发布软件的过程:

直接打开cmd命令行,进入到windeployqt.exe所在目录 输入:windeployqt.exe 应用程序完整路径,回车。

这样发布出来的应用程序可能会崩溃或者出现以下问题

面对这个错误没有经验的话,很难解决,特别是软件直接崩溃的话,更无从下手。要解决这个问题,估计至少要半天时间。

0xc000007b是一个经典错误,它代表着程序启动时使用了不正确的版本的库,导致无法正常运行。例如,64位的软件使用了32位的库。

所以,发生上面错误的原因是,windeployqt.exe从系统的环境变量路径PATH中找到了其他版本的依赖库,而这个依赖库并不是我们的应用程序真正依赖的那个版本。当你的计算机中安装了很多软件,某些软件会添加系统环境变量,指向自己的bin目录;抑或是安装了几个版本的Qt开发环境时,难免会导致搜索路径中有同名称的、不同版本的库存在,这些情况下,库版本错乱的问题经常发生。

在Qt命令行中输入 echo %PATH%,可以查看当前Qt使用的环境变量:

上图中红色框内是此版本Qt的库文件目录,已添加到当前PATH环境变量的最开头,将会被windeployqt.exe优先搜索到。如此一来,Qt相关的库便不会产生库版本错误的问题。

3.2 坑点二:未使用与Qt版本对应的windeployqt.exe

发布软件时,必须确定项目开发所使用的Qt版本,并使用此版本Qt安装目录下的windeployqt.exe完成发布过程。每个Qt版本中的工具只有在此Qt版本下才能确保正常工作,混用会引入未知的风险。

3.3 坑点三:发布时,默认文件不会覆盖

在Qt命令行终端中多次执行发布命令时,已发布到应用程序文件夹中的文件默认不会被覆盖。当你第一次发布出问题时,调整好环境后再次发布并不会覆盖已存在的文件。这可能和我们期望的不太一样。可以通过添加强制覆盖参数--force强制覆盖已存在的文件,如下图所示:

建议始终添加--force参数,防止因文件未覆盖而出现问题。

3.4 运行库问题

Qt命令行启动时有一行提示:

上面打包输出界面的红框中,有这样一行警告:

Warning: Cannot find Visual Studio installation directory, VCINSTALLDIR is not set.

意思是说,因为我们没有运行vcvarsall.bat,所以VS的环境变量没有配置好,所以不会拷贝VS相关的依赖库。

vcvarsall.bat是VS的自带的配置环境变量的批处理文件。

在VS2015及更早VS版本下:

以VS2010为例,它位于路径 C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC 下。它属于VS命令行工具的一部分,这里不多说,直接去看VS官网文档即可:通过命令行使用 Microsoft C++ 工具集

那我们就尝试运行vcvarsall.bat来配置一下VS的环境。整个过程的完整操作过程界面如下:

可以看到,那一行警告不见了。同时,应用程序目录下多了两个库文件,如下图:

 【*************************************************************】

 "D:\software\vs2022\IDE\VC\Auxiliary\Build\vcvars64.bat"

【*************************************************************】

这样发布出来的目录就带上了VS的依赖库,拷贝到没有安装VS的电脑上亦可以运行。

VS2017及以后VS版本:

vcvarsall.bat的位置有所变动,一般在

C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build。

更高版本的VS在版本对应的目录下即可找到。

通用方法

打包软件时,附上对应版本的vcredist.exe微软运行库给用户,用户在使用软件前,先安装对应版本的微软运行库,程序依赖的运行库就可以安装到系统中,程序即可顺利运行。

因为Qt Creator开发环境也是用Qt+VS开发的,所以Qt Creator安装目录下是带有vcredist.exe微软运行库的,我们直接拿过来用即可。

4. 命令帮助

除本文提及的基本参数,发布程序还提供了一些额外参数选项,可以通过查看命令帮助了解。

在Qt命令行终端中输入

windeployqt.exe -h

可以查看命令帮助。

5. 结语

总体来说,虽然发布步骤比较简单,但是有坑有细节,自己尝试操作几次就能熟悉了。里面的坑笔者踩过,会浪费很多时间,希望大家能避免踩坑,提高效率。

标签:exe,Qt,windows,windeployqt,避坑,VS,应用程序,版本
From: https://www.cnblogs.com/zbtblogs/p/18358882

相关文章

  • windows下安装部署
    1.安装1.1官网下载Foundationstar下载解压缩1.2官网下载Agentstar下载解压缩2.修改配置2.1agents把解压的agents放到Foundations,改下文件夹名2.2端口修改webapp->application.yml2.3数据保存修改config->application.ymlmysql存储mysql账号密码修......
  • 宝塔Windows面板环境要求
    操作系统:仅支持WindowsServer2008R2/2012/2016/2019/2022,64位系统(暂不支持Windows家庭环境使用)确保是干净的操作系统,没有安装过其它环境带的Apache/Nginx/php/MySQL/pgsql/gitlab/java(已有环境、网站在运行的不可安装) :-: 重要的事情提前说,重要的事情说三遍,已有环境不......
  • Windows 内存压缩(Memory Compression)是一种内存管理技术,通过压缩内存中的数据来减少物
    内存压缩(MemoryCompression)的起源可以追溯到对内存管理的需求增加的背景下。早期计算机系统主要依赖于物理内存的增加来应对内存压力,但这导致了更高的成本和复杂性。内存压缩技术最初由研究人员和工程师在20世纪80年代和90年代开发,目的是通过软件算法减少内存占用。操作系统和虚......
  • WPBT (Windows Platform Binary Table) 是一种用于在Windows启动时传递信息的结构。它
    WPBT(WindowsPlatformBinaryTable)的起源可以追溯到Windows操作系统对ACPI(AdvancedConfigurationandPowerInterface)规范的扩展需求。ACPI是一个用于管理硬件配置和电源管理的标准,广泛用于操作系统与固件之间的通信。WPBT是这种规范的一部分,专门设计用于Windows环境。......
  • windows核心编程 第三章,跨越进程边界共享内核对象,对象句柄的继承性,改变句柄的标志,命名
    windows核心编程3.3跨越进程边界共享内核对象3.3.1对象句柄的继承性3.3.2改变句柄的标志3.3.3命名对象3.3.4终端服务器的名字空间3.3.5复制对象句柄文章目录windows核心编程3.3跨越进程边界共享内核对象3.3.1对象句柄的继承性3.3.2改变句柄的标志3.3.3命名......
  • windows系统配置nginx环境运行pbootcms访问首页直接404的问题
    安装pbootcms后访问后台/admin.php可以,但是直接访问首页就404。运行环境运行环境采用的是:windows+nginx+php的环境详细经过客户说伪静态规则一直无法生效,看了一下,代码放到服务器除了后台/admin.php可以访问到,其他页面都是404错误,一直各种尝试导入伪静态,但是所有页面依然是404。......
  • Windows出现出现身份验证错误。要求的函数不受支持 远程计算机: 10.17.1.2 这可能是由
    Windows出现出现身份验证错误。要求的函数不受支持远程计算机:10.17.1.2这可能是由于CredsSP加密数据库修正。若要了解详细信息,请访问https://go.microsoft.com/fwlink/?linkid=866660解决方案解决方法第一步点开控制面板选择系统与安全第二步选择“允许远程访问......
  • Windows超高危漏洞“狂躁许可”实际利用全过程曝光!(附POC)
     自"永恒之蓝"之后,Windows再次暴露出一个影响全版本且高度稳定可利用的预认证远程代码执行(RCE)漏洞。本文将跟随漏洞披露者的第一视角,详细探讨漏洞的技术原理、利用方法,并提供相关的概念验证伪代码。文章同时附有演示视频,展示了该漏洞在最新的WindowsServer2025上的实......
  • C 提高篇 c运行库、c标准库、windows API的区别和联系
    C运行时库函数C运行时库函数是指C语言本身支持的一些基本函数,通常是汇编直接实现的。  API函数API函数是操作系统为方便用户设计应用程序而提供的实现特定功能的函数,API函数也是C语言的函数实现的。区别他们之间区别是:API函数是针对操作系统的,C语言运行时函数则是针对C语言本身......
  • Windows Server 2019 搭建FTP站点制作服务器证书
    制作服务器证书1.在“服务器管理器”中,选择“仪表板>工具>InternetInformationServices(IIS)管理器”。2.在左侧列表单击服务器,然后在服务器主页“IIS”区域,双击“服务器证书”,进入“服务器证书”页面。3.单击“创建自签名证书”  4.输入证书的名称......