皮皮网
皮皮网

【源码收藏 网】【西瓜去水印源码】【thinkphp源码分析教程】源码编译openssl

来源:源码定制网站 发表时间:2024-11-28 21:58:00

1.Windows10下编译64位openssl
2.Nginx编译所需基本库pcre、源码zlib、编译openssl
3.如何在 Windows 下编译 OpenSSL
4.FFmpeg开发笔记(十六)Linux交叉编译Android的源码OpenSSL库
5.Windows下编译OpenSSL3.1.1
6.编译OpenSSL

源码编译openssl

Windows10下编译64位openssl

       在Windows系统下进行位openssl编译,以下为详细步骤:

       准备工具:确保安装了Microsoft Visual Studio,编译并确保已解压openssl源码。源码

       执行编译步骤:

       1.前往Microsoft Visual Studio目录,编译源码收藏 网找到并进入vcvarsall.bat所在目录。源码

       2.在该目录中打开命令提示符,编译执行vcvarsall.bat x_amd命令。源码

       3.切换到openssl源码解压目录,编译注意确保该cmd窗口与上一步的源码窗口在同一位置,以便后续命令执行。编译

       4.在解压目录下,源码使用perl命令进行配置,编译西瓜去水印源码命令格式为:D:\openssl\openssl-1.0.2o>perl Configure VC-WINA --prefix=D:\openssl\install。源码

       5.继续执行ms\do_wina命令。

       6.执行编译,此步骤可能需要较长时间,命令为:D:\openssl\openssl-1.0.2o>nmake -f ms\nt.mak。

       7.继续执行安装命令:D:\openssl\openssl-1.0.2o>nmake -f ms\nt.mak install。

       8.完成编译后,打开D:\openssl\install文件夹,即可找到编译好的文件。

       个人经验分享:自行编译 openssl 过程中耗时较长,且部分教程表述不够清晰准确,故记录分享以供参考。

Nginx编译所需基本库pcre、thinkphp源码分析教程zlib、openssl

       在构建和配置 Nginx Web 服务器时,pcre、zlib 和 openssl 这三个基本库扮演着关键角色。它们各自提供核心功能:pcre 用于正则表达式处理,zlib 用于数据压缩,而 openssl 则确保安全的网络通信。在进行源码编译时,至关重要的是确保系统上安装了这些库的开发版本,以便编译器能够正确链接。

       通常情况下,可以通过包管理器轻松安装这些库的开发版本,按照官方指南进行编译。源码除法逻辑结构然而,如果在编译过程中遇到错误,如提示缺少 openssl-devel,可能是因为缺少了 SSL 模块所需的 OpenSSL 库。解决方法是安装 OpenSSL,或者将其静态编译到 Nginx 中,使用 --with-openssl= 选项。

       对于静态编译,比如指定 pcre 的源码路径,Nginx 将直接包含 PCRE 的代码,不再依赖系统中的动态库。这意味着即使不安装系统库,编译后的棋牌源码已解密 Nginx 仍然能运行,但前提是正确配置了库路径。

       如果选择通过 rpm 包安装 Nginx,比如从 nginx.org/packages 下载的版本,通常情况下,rpm 包已经包含了编译后的 Nginx 二进制文件,因此无需额外安装 pcre-devel、zlib-devel 和 openssl-devel。这意味着在这些情况下,基本库的编译步骤可以省略。

如何在 Windows 下编译 OpenSSL

       å¦‚何在Windows下编译OpenSSL (VS使用VC的cl编译器)

       1、安装ActivePerl//初始化的时候,需要用到perl解释器

       2、使用VS下的Visual Studio Command Prompt进入控制台模式(这个模式会自动设置各种环境变量)

       3、解压缩openssl的包,进入openssl的目录

       4、perl configure VC-WIN

       å°½é‡åœ¨è¿™ä¸ªç›®å½•ä¸‹æ‰§è¡Œè¯¥å‘½ä»¤ï¼Œå¦åˆ™æ‰¾ä¸åˆ°Configure文件,或者指定完整的Configure文件路径。

       5、ms\do_ms.bat

       åœ¨è§£åŽ‹ç›®å½•ä¸‹æ‰§è¡Œms\do_ms.bat命令

       6、nmake -f ms\ntdll.mak

       7、nmake -f ms\nt.mak

       ç¼–译后

       åœ¨openssl解压目录下执行,完成编译后。输出的文件在outdll (6), out (7)里面,包括应用程序的可执行文件、lib文件和dll文件

       æ³¨æ„ï¼šåœ¨è¿è¡Œç¬¬äº”步时,cl编译器会抱怨说.\crypto\des\enc_read.c文件的read是The POSIX name for this item is deprecated(不被推荐的),建议使用_read。呵呵,我可不想将OpenSSL中的所有的read函数修改为_read。再看cl的错误代码error C,于是上MSDN上查找:

       warning treated as error - no object file generated

       /WX tells the compiler to treat all warnings as errors. Since an error occurred, no object or executable file was generated.

       æ˜¯ç”±äºŽè®¾ç½®äº†/WX选项,将所有的警告都作为错误对待,所以。。。

       äºŽæ˜¯æ‰“å¼€OpenSSL目录下的MS目录下的ntdll.mak文件,将CFLAG的/WX选项去掉,存盘。。。

       ç»§ç»­æ‰§è¡Œnmake -f ms\ntdll.mak

       =================================

       ä¸€ã€ç¼–译并安装OpenSSL

       1、按照标准步骤从源代码编译安装OpenSSL

        在编译OpenSSL前,需要正确安装Perl,因为在编译OpenSSL时需要使用到该程序。

        下载最新版本的Perl然后安装之。

        下载最新版本的OpenSSL

        然后将源码解压缩到某个目录(如 C:\openssl-0.9.8j)中。

        进入openssl源码目录。

        cd c:\openssl-1.0.1e

        以下为参照该目录下的文件INSTALL.W的执行过程:

        运行configure:

        perl Configure VC-WIN

        创建Makefile文件:

        ms\do_ms.bat

        编译动态库:

        nmake -f ms\ntdll.mak

        编译静态库:

        nmake -f ms\nt.mak

        测试动态库:

        nmake -f ms\ntdll.mak test

        测试静态库:

        nmake -f ms\nt.mak test

        安装动态库:

        nmake -f ms\ntdll.mak install

        安装静态库:

        nmake -f ms\nt.mak install

        清除上次动态库的编译,以便重新编译:

        nmake -f ms\ntdll.mak clean

        清除上次静态库的编译,以便重新编译:

        nmake -f ms\nt.mak clean

       2、如果嫌麻烦,不想编译,可以直接用别人做好的windows OpenSSL 安装包(我用的是0.9.8j版),

        可以下载 OpenSSL for Windows,直接安装。

       P.S. OpenSSL for Windows 的源代码有一些数据类型和VC6的编译器不兼容,我发现的不兼容的数据类型如下:

       åœ¨OpenSSL安装目录的下的include/bn.h文件中,将

        #define BN_ULLONG unsigned long long

        #define BN_ULONG unsigned long long

        #define BN_LONG long long

        分别修改为:

        #define BN_ULLONG ULONGLONG

        #define BN_ULONG ULONGLONG

        #define BN_LONG LONGLONG

        否则,会出现编译错误。

       äºŒã€ä½¿ç”¨OpenSSL

        在VC中配置使用以上的函数库:

        点击菜单:Tools -> Options,弹出对话框"Options",在该对话框中选择"Directories"标签。

        在"Show directories for:"的"Include files"选项中新增目录"C:\openssl\include";

        "Library files"选择中新增目录"C:\openssl\lib"。

        然后在需要链接OpenSSL函数库的工程中加入如下两句:

        #pragma comment(lib, "ssleay.lib")

        #pragma comment(lib, "libeay.lib")

        其作用是将OpenSSL所需的库导入工程中。

       ä¸‰ã€é—®é¢˜

        我在链接OpenSSL的静态函数库时遇到类似以下的问题:

        Linking...

        msvcrt.lib(MSVCRT.dll) : error LNK: _strchr already defined in libcmtd.lib(strchr.obj)

        ...

        这是由于OpenSSL的静态函数库使用的是了VC的多线程DLL的Release版本,而我的程序使用了多线程静态链接的Release版本。

        调整OpenSSL的静态函数库使用的库函数版本即可,调整过程如下:

        编辑文件 ms\nt.mak,将该文件第行

        "CFLAG= /MD /Ox /O2 /Ob2 /W3 /WX /Gs0 /GF /Gy /nologo -DOPENSSL_SYSNAME_WIN -DWIN_LEAN_AND_MEAN -DL_ENDIAN -DDSO_WIN -D_CRT_SECURE_NO_DEPRECATE -

       D_CRT_NONSTDC_NO_DEPRECATE /Fdout -DOPENSSL_NO_CAMELLIA -DOPENSSL_NO_SEED -DOPENSSL_NO_RC5 -DOPENSSL_NO_MDC2 -DOPENSSL_NO_TLSEXT -DOPENSSL_NO_KRB5 -

       DOPENSSL_NO_DYNAMIC_ENGINE"

        中的"/MD"修改为"/MT"。然后重新编译安装OpenSSL即可。

       å››ã€é™„录:在VC中对C/C++ 运行时库不同版本编译指令说明

        《在VC中对C/C++ 运行时库不同版本编译指令说明》一文中详细介绍了连接不同版本库的编译指令如下:

        C Runtime Library:

        /MD MSVCRT.LIB 多线程DLL的Release版本

        /MDd MSVCRTD.LIB 多线程DLL的Debug版本

        /MT LIBCMT.LIB 多线程静态链接的Release版本

        /MTd LIBCMTD.LIB 多线程静态链接的Debug版本

        /clr MSVCMRT.LIB 托管代码和非托管代码混合

        /clr:pure MSVCURT.LIB 纯托管代码

        C++ Standard Library:

        /MD MSVCPRT.LIB 多线程DLL的Release版本

        /MDd MSVCPRTD.LIB 多线程DLL的Debug版本

        /MT LIBCPMT.LIB 多线程静态链接的Release版本

        /MTd LIBCPMTD.LIB 多线程静态链接的Debug版本

       ===============================================

       ä¸€ 配置编译参数

        配置编译参数是进行OpenSSL编译的第一步,这一步可以确定系统的环境,使用什么编译器,默认安装路径以及其他一些选项.步骤如下:

       1.安装perl:下载ActivePerl-5.8.8.-MSWin-x-.msi,然后点击msi文件进行安装!

       2..配置编译参数:下载openssl-1.0.1e.tar.gz,解压.

       vc:首先在C:\Program Files\Microsoft Visual Studio .NET \VC\bin\目录下执行vcvars.bat,然后在解压后的openssl-1.0.1e目录,执行命令配置编译参数:perl Configure VC-WIN

       bc:在解压后的openssl-0.9.8g目录下执行:perl Configure BC-

       äºŒ 生成批处理文件

        在使用configure脚本配置好的编译参数后,就可以使用批处理命令来生成编译脚本.生成编译脚本根据采用编译器的不同通常使用不同的批处理文件.就目前来说,使用vc编译的时候有三种选择:do_ms,do_masm和do_nasm来创建一系列编译脚本文件,即.mak脚本.步骤如下:

       vc:在openssl-1.0.1e目录下,执行命令来批处理文件:do_ms,do_masm和do_nasm

       bc:1.下载nsm.zip微软汇编编译器,解压,拷贝到c:/windows目录下,修改名称为nasmw.exe;2.在openssl-1.0.1e目录下,执行命令来批处理文件:ms\do_nasm

       ä¸‰ 代码编译

       vc:

       å®Œæˆä¸Šé¢æ­¥éª¤åŽ,可以看到两个关键脚本文件:nt.mak和ntdll.mak.如果我们需要编译后的OpenSSL库是支持动态DLL形式的,那么应该使用ntddll.mak文件进行编译,这样编译完成我们会得到四个与OpenSSL的API库有关文件:ssleay.lib,libeay.lib,ssleay.dll和libeay.dll.执行的编译命令形式如下:nmake -f ms\ntdll.mak

       å¦‚果不希望以动态库的形式使用OpenSSL,那么可以使用nt.mak文件进行编译.这样编译后使用OpenSSL的时候,回直接将代码链接进我们的程序里面.执行命令如下:nmake -f ms\nt.mak

       bc:执行命令来完成代码编译:make -f ms\bcb.mak

       å›› ELSE

       1)

        测试动态库:

        nmake -f ms\ntdll.mak test

        测试静态库:

        nmake -f ms\nt.mak test

        安装动态库:

        nmake -f ms\ntdll.mak install

        安装静态库:

        nmake -f ms\nt.mak install

        清除上次动态库的编译,以便重新编译:

        nmake -f ms\ntdll.mak clean

        清除上次静态库的编译,以便重新编译:

        nmake -f ms\nt.mak clean

       2)

        使用OpenSSL

        在VC中配置使用以上的函数库:

        点击菜单:Tools -> Options,弹出对话框"Options",在该对话框中选择"Directories"标签。

        在"Show directories for:"的"Include files"选项中新增目录"C:\openssl\include";"Library files"选择中新增目录"C:\openssl\lib"。

        然后在需要链接OpenSSL函数库的工程中编译时加入"libeay.lib"就可以了。

FFmpeg开发笔记(十六)Linux交叉编译Android的OpenSSL库

       《FFmpeg开发实战:从零基础到短视频上线》一书中,示例程序主要针对本地音视频文件进行测试。鉴于安全性考虑,众多网络视频都采用了/openssl/open...,各版本openssl的下载页面是github.com/openssl/open...。以年月发布的openssl-3.2.0为例,可以从以下链接下载该版本的openssl源码包:

       github.com/openssl/open...

       将openssl的源码包上传到Linux服务器,解压并进入源码目录,执行以下命令:

       tar zxvf openssl-3.2.0.tar.gz cd openssl-3.2.0

       确认ndk已放置在服务器上,创建编译脚本build_openssl.sh,填入以下脚本内容(注意android-arm表示编译位的so库,no-shared表示只编译静态库不编译动态库):

       #!/bin/bash NDK_HOME=/usr/local/src/android-ndk-re SYSTEM=linux-x_ HOST=aarch-linux-android API= export PATH=$NDK_HOME/toolchains/llvm/prebuilt/$SYSTEM/bin:$NDK_HOME/toolchains/$HOST-4.9/prebuilt/$SYSTEM/bin:$PATH export ANDROID_NDK_ROOT=$NDK_HOME echo "config for openssl" ./Configure android-arm no-shared --prefix=/usr/local/app_openssl -D__ANDROID_API__=$API echo "config for openssl completed" make -j4 make install

       保存并退出build_openssl.sh,执行以下命令编译和安装openssl:

       chmod +x build_openssl.sh ./build_openssl.sh

       2、加载openssl的环境变量

       第一步将openssl安装在/usr/local/app_openssl,并将openssl的pkgconfig路径加载到环境变量PKG_CONFIG_PATH中。Linux系统的profile文件位于用户初始目录的.bash_profile。执行以下命令编辑当前用户的profile文件:

       cd vi .bash_profile

       往.bash_profile文件末尾添加以下一行:

       export PKG_CONFIG_PATH=/usr/local/app_openssl/lib/pkgconfig:$PKG_CONFIG_PATH

       保存并退出.bash_profile后,执行以下命令加载环境变量:

       source .bash_profile

       然后执行以下环境变量查看命令,确保openssl的环境变量已经成功加载:

       env | grep PKG

       3、重新编译FFmpeg启用openssl

       打开《FFmpeg开发实战:从零基础到短视频上线》随书源码的chapter/config_ffmpeg_full.sh,将该文件另存为config_ffmpeg_openssl.sh,并在文件内部这行--enable-libx \的下面增加如下一行配置:

       --enable-openssl \

       将config_ffmpeg_openssl.sh上传到服务器的FFmpeg源码目录,执行以下命令赋予可执行权限:

       chmod +x config_ffmpeg_openssl.sh

       然后运行以下命令配置、编译和安装FFmpeg:

       ./config_ffmpeg_openssl.sh make clean make -j4 make install

       4、将so文件导入App工程

       (1)将FFmpeg交叉编译好的include目录(位于/usr/local/app_ffmpeg/include)整个复制到App工程的src/main/cpp目录下。

       (2)在src\main目录下创建jniLibs目录,并在jniLibs下面创建子目录arm-v8a,将FFmpeg交叉编译好的8个so文件(位于/usr/local/app_ffmpeg/lib)全部复制到arm-v8a目录下。

       (3)将config_ffmpeg_openssl.sh里面启用的几个第三方库的so文件也一起复制到arm-v8a目录下,包括x、x、mp3lame、freetype等。

       (4)打开App工程的cpp代码,将待播放的在线视频地址改为/openssl/openssl)和Perl(perl.org/get.html)。注意,先安装NASM,因为后续的Perl安装会自动添加环境变量,避免安装顺序错误导致的问题。

       2. 编译过程: 选择位的版本,以管理员权限运行VS 的x Native Tools Command Prompt。在源代码目录下,开始编译过程,使用前缀指定绝对路径。

       在编译过程中,你可能会遇到以下报错:

       报错1:如果你遇到“Locale... unsupported”和“Configure”文件找不到的问题,需要设置环境变量LC_ALL为“C”,LANG为“zh_CN.GBK”。

       报错2:“perl”命令不可用。确保已安装Perl并将其路径添加到环境变量中。

       报错3:“nmake”命令未找到。由于nmake是Visual Studio的一部分,你需要安装VS,并在环境变量的“Path”中添加nmake.exe的位置,如C:\Program Files (x)\...\VC\Tools\MSVC\...\bin\Hostx\x。

       完成上述步骤后,你将获得编译成功的OpenSSL。

       3. 版本选择: 如果你想要编译特定版本,例如1.0.2u的x release或debug版本,只需针对相应命令进行操作。

       

参考资料:

(省略参考资料链接)

相关栏目:探索

.重点关注