qt5.8_for_vs2015 and openssl静态编译

简介: 关于qt5.8版本的通用编译参考,现假定已经静态编译了qt5.8版本,需要追加对openssl的静态编译, 就网络network模块进行编译.

关于qt5.8版本的通用编译参考<<qt5.8_for_vs2015静态编译>>,现假定已经静态编译了qt5.8版本,需要追加对openssl的静态编译。

就网络network模块进行编译举例:

1)qt5.8使用的openssl版本为1.0.2,其他平台可以去http://wiki.qt.io/Qt_5.8_Tools_and_Versions查看

2)去https://www.openssl.org/source/网站下载v1.0.2o源码版本,另外openssl的源码编译需要perl支持,若没有可取http://www.activestate.com/activeperl/下载,win64或win32看自身需要

3)先安装perl,然后编译openssl

将openssl-1.0.2o.tar.gz解压,启动vs2015的命令工具(x86或win64按自身需要)

进入openssl该解压目录,openssl用到了第三方库文件:

ws2_32.lib gdi32.lib advapi32.lib crypt32.lib user32.lib

,本人的是win8系统,本身有这些库,一般在C:\Program Files (x86)\Windows Kits内,由于该目录存在空格,因此设置一个快捷目录指向需要的库目录,例如

C:\software\OpenSSL_Code_Win64\ex_lib_x64 -> C:\Program Files (x86)\Windows Kits\8.0\Lib\win8\um\x64

阅读INSTALL.W32和INSTALL.W64了解安装命令,需要特别支持的是静态编译(static: nmake -f ms\nt.mak),下面是本人的安装样例:

perl Configure VC-WIN64A no-asm no-hw no-shared --prefix=C:\software\OpenSSL_Code_Win64 -L"%OPENSSL_EX_LIBS%"

ms\do_win64a

执行上述两个命令后会在ms目录下生成nt.mak工程文件,里面EX_LIBS涉及到第三房库的配置,原有的是不指定目录的,

nmake -f ms\nt.mak

nmake -f ms\nt.mak install

编译安装完成后,设置环境变量,qt配置openssl时会查询OPENSSL_LIBS字段,通过环境变量简化配置

      如:

       OPENSSL_DIR = C:\software\OpenSSL_Code_Win64

4)启动vs2015(x64/x86)命令工具,进入qt5.8源码目录,例如,C:\software\Qt\Qt5.8.0\5.8\Src\

删除config.cache文件

配置编译环境

 $ set QTDIR=C:\software\Qt\Qt5.8.0\5.8\msvc2015_64
 $ set PATH=%PATH%;%QTDIR%\bin
 $ set QMAKESPEC=win32-msvc2015

qt静态编译配置,假设已经做过qt源码静态编译可跳过,假设qt安装路径C:\software\Qt\Qt5.8.0,进\5.8\msvc2015_64\mkspecs\common目录,打开msvc-desktop.conf文件,修改
        QMAKE_CFLAGS_RELEASE    = -O2 -MD
        QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -MD -Zi
        QMAKE_CFLAGS_DEBUG      = -Zi -MDd
        改为:
        QMAKE_CFLAGS_RELEASE    = -O2 -MT
        QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -MT -Zi
        QMAKE_CFLAGS_DEBUG      = -Zi –MTd

        修改:
        在QMAKE_LEXFLAGS后面加上 –static

配置命令(为了排版下列命令有换行,实际需连续的)脚本conf.bat,配置完成运行,红色部分为新增配置:

configure -confirm-license -opensource -platform win32-msvc2015 -debug-and-release -static -openssl-linked -force-debug-info -prefix "C:\software\Qt\Qt5.8\5.8\msvc2015_64_static" -qt-sqlite -qt-pcre -qt-zlib -qt-libpng -qt-libjpeg -opengl desktop -qt-freetype -nomake tests -nomake examples -I"%OPENSSL_DIR%\include" -L"%OPENSSL_DIR%\lib" -L"%OPENSSL_EX_LIBS%" OPENSSL_LIBS="$$(OPENSSL_DIR)\lib\libeay32.lib $$(OPENSSL_DIR)\lib\ssleay32.lib ws2_32.lib gdi32.lib advapi32.lib crypt32.lib user32.lib"

 

配置结束后会提示OPENSSL_LIBS需要配置,先不管它

5)进入C:\software\Qt\Qt5.8.0\5.8\Src\qtbase\src\network目录

防止旧编译结果,可以make clean清楚旧数据,另外防止不彻底,去C:\software\Qt\Qt5.8.0\5.8\Src\qtbase\lib目录把network相关的生成文件手动删除掉

修改network.pro文件,追加openssl的头文件,防止单独编译缺失,如下

CONFIG += static

INCLUDEPATH += $$(OPENSSL_DIR)\include

查看qtnetwork-config.pri文件,的OPENSSL_LIBS 是否正确,就是刚才配置命令“conf.bat”的设值,本实例的如下:

OPENSSL_LIBS = C:\\software\\OpenSSL_Code_Win64\\lib\\libeay32.lib C:\\software\\OpenSSL_Code_Win64\\lib\\ssleay32.lib ws2_32.lib gdi32.lib advapi32.lib crypt32.lib user32.lib

6)编译和安装network工程:

qmake -o Makefile network.pro

nmake

nmake install

7)使用,在.pro工程文件中添加

QT += network

其他涉及到openssl调用的模块类似

 

 

目录
相关文章
|
Shell 编译器 Linux
zlib-1.2.11库、libpng-1.6.36库编译及交叉编译 —— 附带shell编译脚本及源码
zlib-1.2.11库、libpng-1.6.36库编译及交叉编译 —— 附带shell编译脚本及源码
552 0
zlib-1.2.11库、libpng-1.6.36库编译及交叉编译 —— 附带shell编译脚本及源码
|
编解码 算法 安全
Qt开发笔记:OpenSSL库介绍、windows上mingw32版本的OpenSSL编译模块化
Qt开发笔记:OpenSSL库介绍、windows上mingw32版本的OpenSSL编译模块化
Qt开发笔记:OpenSSL库介绍、windows上mingw32版本的OpenSSL编译模块化
|
Ubuntu Windows
关于 ubuntu上qt5.9.3使用openssl出现“openssl unsupport platform” 的解决方法
关于 ubuntu上qt5.9.3使用openssl出现“openssl unsupport platform” 的解决方法
关于 ubuntu上qt5.9.3使用openssl出现“openssl unsupport platform” 的解决方法
|
Linux
在Qt Linux环境下编译使用libevent
在Qt Linux环境下编译使用libevent
522 0
|
JavaScript Linux C++
LibreCAD v2.2.0源码编译,使用VS2019+Qt5.12.9+Boost1.71.0环境
LibreCAD v2.2.0源码编译,使用VS2019+Qt5.12.9+Boost1.71.0环境
763 0
|
IDE 编译器 Linux
浅谈Qt的编译方式:qmake/cmake/qbs及qbs被弃用的原因
浅谈Qt的编译方式:qmake/cmake/qbs及qbs被弃用的原因
1870 0
|
Shell C语言 C++
安装llvm、clang指定使用非默认gcc、g++
安装LLVM、clang时不使用系统默认的gcc、g++版本: 官方手册安装文档: We use here the command-line, non-interactive CMake interface.
4777 0
|
数据安全/隐私保护