Linux系统下实现QT程序打包发布

简介: Linux系统下实现QT程序打包发布

一、环境介绍


操作系统环境: ubuntu18.04 64位


QT版本:  5.12


二、打包发布的过程


1.   先使用Release 编译QT程序


2.  程序编译成功后,会在指定目录下生成一个文件夹,里面就包含了可执行程序。


比如:  build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release


3.  在这个(build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release)目录下一个脚本文件


 比如: lib_copy_qt.sh   代码如下:

#!/bin/bash
if [ $# != 1 ]
then
    echo "传参数顺序: ./脚本.sh  <要发布的可执行文件文件>"
    exit 0
fi
LibDir=$PWD/lib
mkdir $LibDir
Target=$1
lib_array=($(ldd $Target | grep -o "/.*" | grep -o "/.*/[^[:space:]]*"))
for Variable in ${lib_array[@]}
do
    cp "$Variable" $LibDir
done

这个脚本的功能就是查找可执行文件的依赖库,将依赖库拷贝到当前目录下的lib文件夹里(这个lib是脚本创建的)。


 linux的ldd命令也可以查找可执行文件的依赖库,这个脚本的功能和ldd命令功能一样,写成脚本是为了方便,查找之后就拷贝过来。


  ldd命令使用方法示例:  

wbyq@wbyq:~/qt_code$ ldd build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release/ffmpeg_code 
  linux-vdso.so.1 (0x00007ffe7a5dd000)
  libavcodec.so.58 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libavcodec.so.58 (0x00007f0c8a764000)
  libavutil.so.56 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libavutil.so.56 (0x00007f0c8a457000)
  libavdevice.so.58 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libavdevice.so.58 (0x00007f0c8a244000)
  libavformat.so.58 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libavformat.so.58 (0x00007f0c89deb000)
  libswscale.so.5 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libswscale.so.5 (0x00007f0c89b60000)
  libQt5Widgets.so.5 => /home/wbyq/Qt5.12.6/5.12.6/gcc_64/lib/libQt5Widgets.so.5 (0x00007f0c89311000)
  libQt5Gui.so.5 => /home/wbyq/Qt5.12.6/5.12.6/gcc_64/lib/libQt5Gui.so.5 (0x00007f0c88ac4000)
  libQt5Core.so.5 => /home/wbyq/Qt5.12.6/5.12.6/gcc_64/lib/libQt5Core.so.5 (0x00007f0c88329000)
  libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f0c87fa0000)
  libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f0c87d88000)
  libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f0c87997000)
  libswresample.so.3 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libswresample.so.3 (0x00007f0c8777a000)
  libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f0c873dc000)
  libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f0c871bf000)
  libx264.so.157 => /home/wbyq/work_pc/x264-snapshot-20181217-2245/_install/lib/libx264.so.157 (0x00007f0c86c93000)
  libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f0c86a74000)
  libavfilter.so.7 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libavfilter.so.7 (0x00007f0c8654c000)
  libxcb.so.1 => /usr/lib/x86_64-linux-gnu/libxcb.so.1 (0x00007f0c86324000)
  libxcb-shape.so.0 => /usr/lib/x86_64-linux-gnu/libxcb-shape.so.0 (0x00007f0c86120000)
  libxcb-xfixes.so.0 => /usr/lib/x86_64-linux-gnu/libxcb-xfixes.so.0 (0x00007f0c85f18000)
  libasound.so.2 => /usr/lib/x86_64-linux-gnu/libasound.so.2 (0x00007f0c85c11000)
  libGL.so.1 => /usr/lib/x86_64-linux-gnu/libGL.so.1 (0x00007f0c85985000)
  libicui18n.so.56 => /home/wbyq/Qt5.12.6/5.12.6/gcc_64/lib/libicui18n.so.56 (0x00007f0c854ec000)
  libicuuc.so.56 => /home/wbyq/Qt5.12.6/5.12.6/gcc_64/lib/libicuuc.so.56 (0x00007f0c85134000)
  libicudata.so.56 => /home/wbyq/Qt5.12.6/5.12.6/gcc_64/lib/libicudata.so.56 (0x00007f0c83751000)
  libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f0c8354d000)
  libgthread-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgthread-2.0.so.0 (0x00007f0c8334b000)
  libglib-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007f0c83034000)
  /lib64/ld-linux-x86-64.so.2 (0x00007f0c8c06b000)
  libpostproc.so.55 => /home/wbyq/work_pc/ffmpeg-4.2.2/_install/lib/libpostproc.so.55 (0x00007f0c82e16000)
  libXau.so.6 => /usr/lib/x86_64-linux-gnu/libXau.so.6 (0x00007f0c82c12000)
  libXdmcp.so.6 => /usr/lib/x86_64-linux-gnu/libXdmcp.so.6 (0x00007f0c82a0c000)
  librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007f0c82804000)
  libGLX.so.0 => /usr/lib/x86_64-linux-gnu/libGLX.so.0 (0x00007f0c825d3000)
  libGLdispatch.so.0 => /usr/lib/x86_64-linux-gnu/libGLdispatch.so.0 (0x00007f0c8231d000)
  libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f0c820ab000)
  libbsd.so.0 => /lib/x86_64-linux-gnu/libbsd.so.0 (0x00007f0c81e96000)
  libX11.so.6 => /usr/lib/x86_64-linux-gnu/libX11.so.6 (0x00007f0c81b5e000)

脚本的使用方法示例:

wbyq@wbyq:~/qt_code$ cd build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release/
wbyq@wbyq:~/qt_code/build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release$ ./lib_copy_qt.sh ffmpeg_code 
wbyq@wbyq:~/qt_code/build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release$ ls
ffmpeg_code  lib_copy_qt.sh  mainwindow.o  moc_mainwindow.cpp  moc_predefs.h
lib          main.o          Makefile      moc_mainwindow.o    ui_mainwindow.h
wbyq@wbyq:~/qt_code/build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release$ 

执行完这一步之后,在当前目录下就会生成一个lib文件夹,然后在其他再创建一个目录,当做最终的APP发布存放目录。


 比如: camera_linux_app


 (1).  将上一步生成的lib目录下的所有文件拷贝到camera_linux_app目录下。


 (2).  将build-ffmpeg_code-Desktop_Qt_5_12_6_GCC_64bit-Release目录下的程序可执行文件也拷贝到camera_linux_app目录下。


 (3).  为了发布过程不出现各种BUG,找不到库、找不到平台等等一系列问题,现在使用一个笨办法。


  将QT使用的编译器目录下的所有库拷贝到camera_linux_app目录下,有覆盖的就不管。


 我的目录路径是: /home/wbyq/Qt5.12.6/5.12.6/gcc_64/lib


 (4).   将QT使用的编译器目录下的plugins文件夹拷贝到camera_linux_app目录下。


 (5).  在camera_linux_app目录下编写一个app启动脚本。 脚本名称和可执行程序的名字样,后缀为.sh。


   比如: 我的可执行程序名字是ffmpeg_code  。那么脚本的名字就是ffmpeg_code.sh


   代码如下:   (因为我的程序用到了FFMPEG相关的库,所有里面加了FFMPEG相关的东西)

#!/bin/sh
LD_LIBRARY_PATH=$PWD/ffmpeg_x264/ffmpeg/lib:$PWD/ffmpeg_x264/x264/lib:$LD_LIBRARY_PATH
echo "LD_LIBRARY_PATH=$LD_LIBRARY_PATH"
PATH=$PATH:$PWD/ffmpeg_x264/ffmpeg/bin
echo "PATH=$PATH"
appname=`basename $0 | sed s,\.sh$,,`
dirname=`dirname $0`
tmp="${dirname#?}"
if [ "${dirname%$tmp}" != "/" ]; then
dirname=$PWD/$dirname
fi
LD_LIBRARY_PATH=$dirname:$LD_LIBRARY_PATH
echo "LD_LIBRARY_PATH=$LD_LIBRARY_PATH"
export LD_LIBRARY_PATH
export PATH
export QT_QPA_PLATFORM_PLUGIN_PATH=$PWD/plugins
$dirname/$appname "$@"

 (6).  脚本代码编写好之后,都要修改权限为可执行。 例如:  chmod 777 xxx.sh


 (7).  将camera_linux_app目录打包。例如:  tar cvf  camera_linux_app.tar camera_linux_app/


 (8).   接下来就可以将这个打包的文件拷贝到其他没有QT环境的电脑上解压运行了。


    运行的时候,执行(camera_linux_app)目录下的脚本文件(ffmpeg_code.sh)即可。


  这样打包占用的空间比较大,拷贝了很多没有用到的库,但是不会出现各种库缺失的问题。

目录
相关文章
|
2月前
|
Ubuntu Linux Anolis
Linux系统禁用swap
本文介绍了在新版本Linux系统(如Ubuntu 20.04+、CentOS Stream、openEuler等)中禁用swap的两种方法。传统通过注释/etc/fstab中swap行的方式已失效,现需使用systemd管理swap.target服务或在/etc/fstab中添加noauto参数实现禁用。方法1通过屏蔽swap.target适用于新版系统,方法2通过修改fstab挂载选项更通用,兼容所有系统。
221 3
Linux系统禁用swap
|
2月前
|
Linux
Linux系统修改网卡名为eth0、eth1
在Linux系统中,可通过修改GRUB配置和创建Udev规则或使用systemd链接文件,将网卡名改为`eth0`、`eth1`等传统命名方式,适用于多种发行版并支持多网卡配置。
329 3
|
Ubuntu Linux 网络安全
Linux系统初始化脚本
一款支持Rocky、CentOS、Ubuntu、Debian、openEuler等主流Linux发行版的系统初始化Shell脚本,涵盖网络配置、主机名设置、镜像源更换、安全加固等多项功能,适配单/双网卡环境,支持UEFI引导,提供多版本下载与持续更新。
293 0
Linux系统初始化脚本
|
2月前
|
安全 Linux Shell
Linux系统提权方式全面总结:从基础到高级攻防技术
本文全面总结Linux系统提权技术,涵盖权限体系、配置错误、漏洞利用、密码攻击等方法,帮助安全研究人员掌握攻防技术,提升系统防护能力。
283 1
|
2月前
|
监控 安全 Linux
Linux系统提权之计划任务(Cron Jobs)提权
在Linux系统中,计划任务(Cron Jobs)常用于定时执行脚本或命令。若配置不当,攻击者可利用其提权至root权限。常见漏洞包括可写的Cron脚本、目录、通配符注入及PATH变量劫持。攻击者通过修改脚本、创建恶意任务或注入命令实现提权。系统管理员应遵循最小权限原则、使用绝对路径、避免通配符、设置安全PATH并定期审计,以防范此类攻击。
1005 1
|
数据安全/隐私保护 C++ 计算机视觉
Qt(C++)开发一款图片防盗用水印制作小工具
文本水印是一种常用的防盗用手段,可以将文本信息嵌入到图片、视频等文件中,用于识别和证明文件的版权归属。在数字化和网络化的时代,大量的原创作品容易被不法分子盗用或侵犯版权,因此加入文本水印成为了保护原创作品和维护知识产权的必要手段。 通常情况下,文本水印可以包含版权声明、制作者姓名、日期、网址等信息,以帮助识别文件的来源和版权归属。同时,为了增强防盗用效果,文本水印通常会采用字体、颜色、角度等多种组合方式,使得水印难以被删除或篡改,有效地降低了盗用意愿和风险。 开发人员可以使用图像处理技术和编程语言实现文本水印的功能,例如使用Qt的QPainter类进行文本绘制操作,将文本信息嵌入到图片中,
484 1
Qt(C++)开发一款图片防盗用水印制作小工具
|
监控 C++ 容器
【qt】MDI多文档界面开发
【qt】MDI多文档界面开发
571 0
|
C++
C++ Qt开发:QUdpSocket网络通信组件
QUdpSocket是Qt网络编程中一个非常有用的组件,它提供了在UDP协议下进行数据发送和接收的能力。通过简单的方法和信号,可以轻松实现基于UDP的网络通信。不过,需要注意的是,UDP协议本身不保证数据的可靠传输,因此在使用QUdpSocket时,可能需要在应用层实现一些机制来保证数据的完整性和顺序,或者选择在适用的场景下使用UDP协议。
760 2