开发环境
- 编译环境:Win10 1903 X64
- 开发工具:VS2015
- 额外工具:构建OPENSSL还需要Perl
- 所需源码:zlib1211.zip | openssl-1.0.2t.tar.gz | mysql-connector-c-6.1.11-src.zip
1 | cd C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\ |
静态编译zlib
1 | cd D:\test\zlib-1.2.11\ |
最后使用VS2015打开:D:\test\zlib-1.2.11\contrib\vstudio\vc14\zlibvc.sln
生成解决方案后进入:D:\test\zlib-1.2.11\contrib\vstudio\vc14\x64
zlibvc 是动态链接库,zlibstat 是静态链接库。
静态编译openssl
1 | cd D:\test\openssl-1.0.2t |
静态编译MySQL-Connector
1 | cd D:\test\mysql-connector-c-6.1.11-src\ |
测试静态编译的MySQL和OpenSSL项目
在VS2015中如下配置项目属性:
项目属性 –> C/C++ –> 代码生成 –> 运行库 –> MT (D用于动态,T用于静态,带d的是debug模式的)
项目属性 –> VC++ –> 包含目录 -> D:\test\mysql\include;D:\test\openssl\include
项目属性 –> VC++ –> 库目录配置 -> D:\test\mysql\lib;D:\test\openssl\lib
项目属性 –> 链接器 –> 输入 –> 附加依赖项 –> libeay32.lib;ssleay32.lib;mysqlclient.lib
测试例子:
1 |
|
其他技巧
- MySQL官方的动静态库
打开你的MySQL安装目录C:\Soft\mysql-5.7.28-winx64\lib\,libmysql.lib和libmysql.dll为动态库,mysqlclient.lib为静态库。
- 检查库文件是动态还是静态库
可以用7zip打开库文件。如果里面内容后缀显示为xxx.dll则为动态库的导入文件,后缀显示为xxx.obj则为VS的静态库。后缀显示为xxx.o则为GCC的静态库。
- 转换VS的.lib/.dll动态库为GCC的.a动态库
1 | reimp -d libmysql.lib # 生成libmysql.def的老方法,不推荐 |