利用QT自带的windeployqt打包发布程序

本文介绍如何使用windeployqt工具简化Qt程序的发布流程,包括QtWidgetsApplication和QtQuickApplication两种类型的程序。此外,还详细介绍了如何利用NSIS编辑器创建个性化的安装包。

●◎◇写在前面:本文是本人搜集整理网上的资料弄出来的。出处如下:

◆步骤一出处:感谢作者:winland0704       原文:http://tieba.baidu.com/p/3730103947,


◆步骤二出处:感谢作者:╰☆奋斗ing❤孩子`  原文:http://blog.sina.com.cn/s/blog_a6fb6cc90101fer8.html。 


◆技术在于交流、沟通,转载请注明出处并保持作品的完整性。

步骤一:windeployqt的用法

Qt 官方开发环境使用的动态链接库方式,在发布生成的exe程序时,需要复制一大堆 dll,
如果自己去复制dll,很可能丢三落四,导致exe在别的电脑里无法正常运行。
因此 Qt 官方开发环境里自带了一个工具:windeployqt.exe。
以官方 Qt 5.4.0+MinGW 开发环境为例,
从开始菜单--》Qt 5.4.0--》5.4--》MinGW 4.9 (32-bit)--》Qt 5.4 for Desktop (MinGW 4.9 32 bit),可以打开 Qt 命令行,从这里就可以执行 windeployqt 工具。


集成开发环境 QtCreator 目前生成图形界面程序 exe 大致可以分为两类:
Qt Widgets Application 和 Qt Quick Application。
下面分别介绍这两类exe 的发布方式。


1、Qt Widgets Application可执行程序发布方式
首先用 QtCreator 新建一个 Qt Widgets Application 项目,直接用默认的 QMainWindow 程序就可以了,项目名字假定是 hellomw。
然后以 Release 方式编译生成 exe 程序:


生成的程序运行正常之后,找到项目的生成目录,比如 项目源码路径:
C:\QtPros\hellomw\
它的项目生成目录是
C:\QtPros\build-hellomw-Desktop_Qt_5_4_0_MinGW_32bit-Release\
进入这个文件夹,在进入它的子文件夹 release 里面,找到 hellomw.exe ,
将这个exe 复制到一个新的单独的文件夹里用于发布,比如存到 
D:\hellomw\ 文件夹里面。


然后从开始菜单打开 Qt 命令行,输入命令 :
cd /d D:\hellomw
然后使用 windeployqt 工具命令:
windeployqt hellomw.exe


然后可以在 D:\hellomw 文件夹里看到 windeployqt 工具自动复制的插件文件夹
和 dll文件、qm文件。这时候得到的就完整的 exe 程序发布集合,依赖关系都解决好了。


把 D:\hellomw 文件夹 打包就可以发布了,不用自己一个个找 dll 文件了。
D:\hellomw 文件夹里的qm文件是多国语言翻译文件,不需要可以删了,
其他的都保留。


2、Qt Quick Application发布方式
首先用 QtCreator 新建一个 Qt Quick Application 项目,直接用默认的项目模版,点击下一步生成项目,项目名字假定是 helloqml。
然后以 Release 方式编译生成 exe 程序:


然后找到项目的构建目录,比如项目源码目录 C:\QtPros\helloqml,
它的构建目录是:
C:\QtPros\build-helloqml-Desktop_Qt_5_4_0_MinGW_32bit-Release\
进入这个目录,再进入 release 子文件夹,找到 helloqml.exe ,
复制到一个新的单独的文件夹里面,比如 D:\helloqml\ 文件夹里面。


然后从开始菜单打开 Qt 命令行,进入D:\helloqml\文件夹:
cd /d D:\helloqml
然后使用 windeployqt 工具命令:
windeployqt helloqml.exe --qmldir C:\Qt\Qt5.4.0\5.4\mingw491_32\qml


注意不要跟烧包一样照抄上条命令,--qmldir 是指出 Qt 库里面的 qml 文件夹位置,
上面命令里 C:\Qt\Qt5.4.0 是 Qt 官方开发环境安装的文件夹,
C:\Qt\Qt5.4.0\5.4\mingw491_32 是Qt类库的目录(QTDIR),
因此使用的 --qmldir 后面写的是 C:\Qt\Qt5.4.0\5.4\mingw491_32\qml 
读者Qt环境安装路径不一样,要根据实际情况修改!


然后可以看到 D:\helloqml 文件夹里有一大堆文件,就是 QtQuick程序需要的依赖文件。
将整个 D:\helloqml 文件夹 打包就可以发布出去,在别的电脑上使用。


这个 D:\helloqml 文件夹里的东西很多,看不懂就不要删,老老实实打包发布就行了。


上面是最简单的程序发布,实际复杂程序可能还带一些图片文件、数据库文件、配置文件之类的,可以按自己需要添加这些文件到发布文件夹里面。

步骤二:利用NIS Edit打包

关于NSIS
1、NSIS简介
(1)NSIS是什么?
      一款免费的Win32安装、卸载系统!
(2)NSIS有什么特点?
      脚本简洁高效、系统开销小,进行安装、卸载、设置、解压文件也不在话下,几乎可以做所有的事情。

2、工具
      NSIS Edit + NSIS

3、使用方式
      脚本向导 + 修改代码 = 个性化安装包

准备文件
      以下是我即将打包的所有文件,安装包目录结构(包括:可执行程序、 插件库、运行时库、授权文件、卸载程序图标等等!)如下图所示:
Qt之打包发布(NSIS详解)
1、利用向导制作安装包:
Qt之打包发布(NSIS详解)

2、填写应用程序基本信息

Qt之打包发布(NSIS详解)

3、指定安装程序所用选项
       注意:这里选择语言为SimpChinese
Qt之打包发布(NSIS详解)

4、设置应用程序安装目录与授权文件

Qt之打包发布(NSIS详解)

5、指定应用程序文件

Qt之打包发布(NSIS详解)

6、指定创建应用程序图标

Qt之打包发布(NSIS详解)

7、选择安装程序完成后运行的动作

Qt之打包发布(NSIS详解)

8、指定接触安装程序属性

Qt之打包发布(NSIS详解)

9、进行脚本编译、保存

Qt之打包发布(NSIS详解)

10、等待编译完成,即可运行打包后的安装包
Qt之打包发布(NSIS详解)

      大功告成之后,即可进行安装!

(1)安装程序

Qt之打包发布(NSIS详解)

(2)此处显示授权文件中的内容

Qt之打包发布(NSIS详解)

(3)选择安装目录

Qt之打包发布(NSIS详解)

(4)运行程序,并显示“自述文件”

Qt之打包发布(NSIS详解)

(5)运行结果

Qt之打包发布(NSIS详解)

      关于Qt的打包工具了解一些,个人感觉NSIS用起来比较顺手,脚本修改起来也方便,所以就推崇一下。。。若想将安装包变得更加美观,则需要手动修改脚本,更多信息请查找相关资料,此处不再多做介绍!






### 作用 `windeployqt` 是 Qt 提供的一个工具,用于在 Windows 平台上将 Qt 应用程序及其依赖项打包。它的主要作用是自动收集应用程序所需的动态链接库(DLL)和其他资源文件,并将它们复制到可执行文件所在的目录中,以便确保程序可以正常运行[^1]。 通过 `windeployqt` 工具,可以简化手动查找和复制依赖库的过程,尤其适用于使用动态库构建的 Qt 应用程序。对于 QML 项目,该工具还可以处理 QML 模块的依赖关系[^2]。 ### 使用方法 #### 基本命令格式 基本的命令格式如下: ```bash windeployqt [选项] [路径或可执行文件] ``` #### 示例命令 以下是一个典型的发布命令示例: ```bash D:\Qt\6.7.1\mingw_64\bin\windeployqt --release --no-quick-import --no-compiler-runtime D:\Qt\Qt\release\qWidgets.exe ``` 此命令会为 `qWidgets.exe` 可执行文件部署必要的运行时库,同时跳过 Quick 模块导入并排除编译器运行时[^1]。 #### 非 QML 项目的发布 对于非 QML 项目,可以直接运行以下命令: ```bash windeployqt xxxx.exe ``` 完成后,还需要手动将所有用到的第三方动态库拷贝到目标文件夹中。静态库需要额外操作,因为它们已经被包含在可执行文件中[^2]。 #### QML 项目的发布 如果是 QML 项目,则需要指定 QML 文件所在的目录。例如: ```bash windeployqt --qmldir qml xxxx.exe ``` 其中 `qml` 是存放 QML 文件的子目录。此命令会根据 QML 文件的依赖关系自动部署所需的模块[^2]。 #### 参数说明 - `--release`: 表示发布的是 Release 版本。 - `--no-quick-import`: 跳过对 Qt Quick 的导入处理。 - `--no-compiler-runtime`: 部署编译器运行时库。 - `--qmldir <dir>`: 指定 QML 文件所在的目录,用于处理 QML 模块的依赖关系[^1]。 #### 环境变量配置 为了方便使用,可以将 `windeployqt` 所在的目录添加到系统的环境变量中。这样可以在任意位置直接调用该工具而无需输入完整路径[^2]。 #### 文件结构建议 建议将生成的可执行文件单独放到一个文件夹中,然后在此文件夹下运行 `windeployqt` 命令。这有助于保持部署过程的清晰和可控[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值