本站提供最佳带app商城源码服务,欢迎转载和分享。

【陪玩下单源码】【风口火种源码】【es源码多大】openssl编辑源码_openssl源码编译

2025-01-24 13:08:31 来源:做源码资本违法吗 分类:娱乐

1.Windows下编译OpenSSL3.1.1
2.如何在 Windows 下编译 OpenSSL
3.Windows10下编译64位openssl
4.编译OpenSSL
5.Windows下openssl的编编译下载安装和使用方法

openssl编辑源码_openssl源码编译

Windows下编译OpenSSL3.1.1

       OpenSSL是一个强大的安全套接字层密码库,广泛用于加密HTTPS和SSH。辑源它远不止是源码一个库,还是编编译一个多用途、跨平台的辑源密码工具。

       编译环境和依赖工具

       为了方便编译OpenSSL,源码陪玩下单源码需要安装Strawberry Perl和NASM。编编译Strawberry Perl的辑源下载地址是Strawberry Perl for Windows,而NASM是源码汇编器,其下载地址为NASM。编编译安装Strawberry Perl后,辑源会自动添加到环境变量中,源码但NASM不会自动添加。编编译确保在环境变量Path中添加NASM.exe所在的辑源目录,避免编译时出现错误。源码

       编译步骤

       从GitHub下载OpenSSL源码,具体地址为GitHub - openssl/openssl: TLS/SSL and crypto library。进入源码所在目录后,风口火种源码执行编译命令。编译过程大约需要分钟。注意,使用--prefix选项指定安装路径时,必须是绝对路径。若未指定或使用非管理员权限执行,可能会出现Permission Denied错误。

       可能遇到的问题

       1、在编译过程中,可能会遇到“Could Not Find D:\SourceCode\openssl-3.1.1\libcrypto-3-x.*”的错误。解决此问题的方法是在Shell中通过命令:path d:\nasm\path;%PATH%配置NASM环境变量,这通常可以解决该错误。

       2、在安装过程中,可能出现“Cannot create directory C:/Program Files/Common Files/SSL: Permission denied”的错误。解决方法是使用管理员身份运行Shell,因为OpenSSL在安装时会创建C:\Program Files\Common Files中的es源码多大SSL目录。

       总结

       OpenSSL的编译相对简单,但确保正确配置环境和路径。如遇问题,可以在评论中提问,或关注同名GZH并回复openssl以获取下载链接。

如何在 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"就可以了。

Windows下编译位openssl

       为了在Windows 系统下编译位的openssl,我们首先需要准备一些工具。确保安装了Microsoft Visual Studio,这是进行编译工作所需的重要环境之一。接下来,通过搜索vcvarsall.bat文件并进入其所在目录,准备启动编译过程。

       接下来,在打开的命令提示符中执行vcvarsall.bat x_amd 命令,这一步是为编译器设置正确的环境变量。然后,使用解压后的源码海洋破解openssl源码文件所在的目录下的命令行,执行perl Configure VC-WINA --prefix=D:\openssl\install。这里的--prefix参数用于指定编译后的openssl库的安装路径。

       继续执行ms\do_wina命令,随后,通过输入nmake -f ms\nt.mak启动编译工作,这可能需要几分钟时间。紧接着,执行nmake -f ms\nt.mak install命令,完成编译和安装步骤。

       当编译过程完成后,打开D:\openssl\install文件夹,可以发现刚编译出的openssl库文件。整个编译过程比较繁琐,有许多教程在细节上描述不够清晰,因此特意记录下这一过程,希望对其他开发者有所帮助。

编译OpenSSL

       要编译OpenSSL,桌球源码lua首先确保你的环境准备如下:

1. 准备工作: 下载并安装必要的工具,包括openssl(github.com/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版本,只需针对相应命令进行操作。

       

参考资料:

(省略参考资料链接)

Windows下openssl的下载安装和使用方法

       安装openssl有两种方式,第一种直接下载安装包,装上就可运行;第二种可以自己下载源码,自己编译。下面对两种方式均进行详细描述。

一、下载和安装openss

       方法一:直接使用openssl安装包

       Window 的openssl的安装包的下载地址为:

       一般在安装openssl之前还需要vs的一些插件,该地址中也提供了相关插件的下载。如下图即为openssl的安装及其vs插件在下载网页的截图。

方法二:自己编译openssl

       此过程比较复杂,需要先安装perl、vs等软件,然后才能编译openssl。

1、下载并安装perl,

1)下载路径:

       /activeperl/downloads/

2)安装与配置:

       直接运行安装文件(例如:ActivePerl-5..3.-MSWin-x-.msi)即可完成安装;安装过程将自动完成环境变量的配置(安装完成之后,可以在系统环境变量里看到perl的bin目录(例如: C:\Program Files\perl\site\bin;)已经被加入进来),无需再手工配置;

3)测试安装是否成功:

       进入perl安装目录的eg文件夹,执行perl example.pl若显示Hello from ActivePerl!,则说明Perl安装成功。如下图所示:

       perl安装成功之后就可以开始使用Perl的相关命令来进行OpenSSL的安装了。

2、openssl可以自己下载源码编译也可以直接下载安装包安装完之后即可使用。

2.1使用源码编译openssl

1) 下载openssl源码的路径:

       /blog/static//

下面将使用一个现成的ca文件(ca.key和ca.crt)生成证书文件(client.key和client.crt):

1)创建一个目录用于存放ca文件以及将要生成的证书文件,本例中将该目录创建在outdll目录下:C:\Program Files\openssl-1.0.1g\outdll\test,

2)执行命令生成证书的key文件:..\openssl genrsa -out client.key ,如下图所示:

       3) 生成证书请求文件:..\openssl req -out server.csr -key server.key -new

4) 生成证书文件:..\ openssl x -req -in client.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out client.crt -days

下面是其他网友的补充:

       安装环境:

       操作系统:window7(位)

       C++编译器:VS

       工具下载:

       下载ActivePerl-5.或5.(其他版本也可以):

       下载地址:/activeperl/downloads/ (安装过程只要按照Windows下一般程序的安装步骤进行即可)

       下载openssl-1.0.1g(其他版本也可以)并解压

       下载地址:http://www.openssl.org/source/(建议解压后的文件路径为C:\openssl,PS:只是为了下文的内容匹配,并且方便寻找,其他路径也无不影响)。

安装Perl

       (我的安装目录为C:\Perl)

       运行CMD命令,使用cd命令将运行目录指向perl安装目录的eg文件夹, 执行perl example.pl若显示Hello from ActivePerl!,则说明Perl安装成功,可以开始使用Perl的相关命令来进行OpenSSL的安装了。

       (PS:如果你想看看原始的INSTALL文件,那么请打开OpenSSL的解压缩目录,下面有两个文件INSTALL.W和INSTALL.W,用记事本方式打开,你可以看到详细的关于安装的解释)

安装openssl

       (最关键的步骤来了)

       1)首先设定好环境变量,这步参照网上的教程后发现后面的编译步骤不成功,找了很就才发现是这部设置的不对才导致的。

       设定环境变量:桌面计算机图标右键-属性-高级系统设置-环境变量-在系统变量当中找到变量名称为path的变量(如果没有找到这新建)点击编辑-在变量名称中填入C:\Program Files (x)\Microsoft Visual Studio .0\VC\bin;C:\Perl\bin;c:\windows\system-点击确定完成设定。(说明:C:\Program Files (x)\Microsoft Visual Studio .0\VC\bin路径是VS的路径。C:\Perl\bin是运行perl的路径,不若不设定那么perl命令将找不到。c:\windows\system这个路径很少提到但是很重要,如果不设置那么会造成后面vcvars.bat环境变量执行出错。)到此环境变量路径设置好之后重启下电脑才能生效。

       2)使用Visual Studio命令提示()进入控制台模式

       开始菜单-所有程序-Microsoft Visual Studio -Visual Studio Tools-Visual Studio命令提示(),(PS:以管理员身份运行), 使用cd命令将目录指向C:\Program Files (x)\Microsoft Visual Studio .0\VC\bin(PS:自己的VC安装路径), 命令行键入vcvars,运行vcvars.bat..完成后进入OpenSSL源码的目录(C:\openssl)

       3)执行Configure命令(配置编译参数)(需将目录跳到OpenSSL源码目录下)

       在命令行中键入perl configure VC-WIN --prefix=c:\openssl(PS:--prefix=c:\openssl命令为指定安装位置)

       4)运行ms\do_ms命令(需将目录跳到OpenSSL源码目录下)

       在命令行中键入ms\do_ms。

       5)运行nmake -f ms\ntdll.mak命令进行代码编译(需将目录跳到OpenSSL源码目录下)

       编译分两种情况,生成静态库和动态库

       (1) 如果是编译OpenSSL动态库,则在命令行键入 nmake -f ms\ntdll.mak

       编译成功课在文件夹outdll里面查看输出的文件,包括应用程序的exe文件、lib文件、dll文件。

       (2) 如果是编译OpenSSL静态库,则在命令行键入 nmake -f ms\nt.mak

       编译成功课在文件夹out里面查看输出的文件,包括应用程序的exe文件、lib文件。

       6)测试使用命令nmake -f ms\ntdll.mak test(若安装成功则可以使用此命令来验证)

       使用openssl

       当VS工程需要用到openssl库时,在包含目录中胎添加openssl安装目录的include目录, 来库目录中添加outdll目录。

       或者将OpenSSL下的include文件夹、lib文件、dll文件考出,使用的时候包含进去就行了。

       另外还有几个命令可能会用到:

       测试OpenSSL动态库:nmake -f ms\ntdll.mak test

       测试OpenSSL静态库:nmake -f ms\nt.mak test

       安装OpenSSL动态库:nmake -f ms\ntdll.mak install

       安装OpenSSL静态库:nmake -f ms\nt.mak install

       清除上次OpenSSL动态库的编译,以便重新编译:nmake -f ms\ntdll.mak clean

       清除上次OpenSSL静态库的编译,以便重新编译:nmake -f ms\nt.mak clean

【本文网址:http://04.net.cn/news/39b323796723.html 欢迎转载】

copyright © 2016 powered by 皮皮网   sitemap