OpenSSL 3.14版本使用VS编译

https://github.com/openssl/openssl/tree/openssl-3.1

下载 OpenSSL3.14 源码下载并解压

安装 perl 脚本解释器

安装 nasm 汇编器默认会安装到用户目录

nasm 路径加入到环境变量path中

C:\Program Files (x86)\NASM

安装好后,重新打开控制台能够运行nasm 和perl命令

 编译工具:VS2022

 编译步骤

(1)进入控制台(运行 CMD),或者编写批处理bat文件

或者直接运行菜单中的vs2022 命令行编译工具,选择相应的版本(x86和x64)

(2)运行vs编译环境

打开菜单中VS中有对应的命令行工具,把地址复制过来

"C:\Program Files\Microsoft Visual Studio\2022\Professional\VC\Auxiliary\Build\vcvars32.bat"

编译64位库版本

"C:\Program Files\Microsoft Visual Studio\2022\Professional\VC\Auxiliary\Build\vcvars64.bat"

(3)进入openssl源码吗目录

cd openssl-3.14

(4)使用perl生成makefile文件

新版本的openssl 不在支持SSLv3 需要修改/Configure 文件,

- TLS 1.2 和 TLS 1.3 推荐使用
- TLS 1.1 也还可以接受
- TLS 1.0 不建议使用

perl Configure { VC-WIN32 | VC-WIN64A | VC-WIN64I | VC-CE } --prefix=%OUTPATH%

perl Configure VC-WIN32 -static no-shared enable-ssl3 enable-ssl3-method --prefix=c:\build

perl Configure VC-WIN64A -static no-shared --prefix=c:\build

VC-WIN32 表示生成32位程序 --prefix 是编译后输出的路径,默认会生成到C:Program Files (x86)目录,因为要写到C盘,有可能会出错,如果控制台不是管理员方式运行

(5)用nmake编译

#编译库源码

nmake

#编译测试程序

nmake test

# 安装openssl

nmake install

将编译好的文件安装到指定目录,默认是C:Program Files (x86)OpenSSL,如果是在C盘,运行控制台是需要有管理员权限

2.5 编译中的一些错误

'perl' 不是内部或外部命令,也不是可运行的程序

需要安装perl

NMAKE : fatal error U1064: 未找到 MAKEFILE 并且未指定目标

perl 生成makefile失败,可以清理掉重新生成,或者替换参数重新生成

NASM not found - make sure it's installed and available on %PATH%

安装nasm或者配置取消nasm

It looks like you don't have either nmake.exe or dmake.exe on your PATH, so you will not be able to execute the commands from a Makefile. You can install dmake.exe with the Perl Package Manager by running:

ActivePerl-5.26.3.XXXX.msi安装后,执行命令行会出现如下提示而无法继续。

Can't locate Win32/Console.pm in @INC (you may need to install the Win32::Console module) (@INC contains: C:\Perl64\site\lib C:\Perl64\lib) at C:\Perl64\lib/ActivePerl/Config.pm line 400.

解决办法,修改C:\Perl64\site\lib\ActivePerl\Config.pm,大约在400行左右:

# Prevent calling Win32::Console::DESTROY on a STDOUT handle
#my $console;
sub _warn {
#    my($msg) = @_;
#    unless (-t STDOUT) {
#	print "\n$msg\n";
#	return;
#    }
#    require Win32::Console;
#    unless ($console) {
#	$console = Win32::Console->new(Win32::Console::STD_OUTPUT_HANDLE());
#    }
#    my($col,undef) = $console->Size;
#    print "\n";
#    my $attr = $console->Attr;
#    $console->Attr($Win32::Console::FG_RED | $Win32::Console::BG_WHITE);
#    for (split(/\n/, "$msg")) {
#	$_ .= " " while length() < $col-1;
#	print "$_\n";
#    }
#    $console->Attr($attr);
#    print "\n";
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenSSL和cURL都是常用的加密和网络通信,为很多开源项目和应用程序提供了安全和通信功能的支持。 OpenSSL是一个强大的开源加密,提供了一系列加密算法和协议的实现,如SSL/TLS、RSA、AES等。它不仅可以用于数据加密和身份验证,还可以进行证书管理和数字签名等操作。OpenSSL作为一个动态可以被其他应用程序链接和使用。 cURL是一个功能强大的开源网络传输工具,支持多种网络协议如HTTP、FTP、SMTP等。它可以用于文件上传、下载和访问远程资源,还可以进行cookie管理和代理配置等。cURL同样作为一个动态可以被其他应用程序链接和使用。 在使用这两个时,需要注意以下几点: 1. 功能和用途:OpenSSL主要用于加密和安全通信,提供了各种加密算法和协议的实现,而cURL主要用于网络传输和资源访问。根据实际需求选择合适的。 2. 兼容性:根据项目的需求,选择适合的OpenSSL和cURL版本。确保版本与操作系统、编译器和其他依赖之间的兼容性。 3. 安全性和漏洞修复:由于OpenSSL和cURL是开源项目,会不断发布新的版本来修复安全漏洞和错误。及时更新到最新版本可以提高应用程序的安全性。 4. API和文档:了解和熟悉OpenSSL和cURL提供的API和文档,可以更好地使用它们的功能和特性。这样可以减少错误和提高代码质量。 总结而言,OpenSSL和cURL是两个重要的动态,分别提供了加密和安全通信、网络传输和资源访问的功能。在使用时,需要根据项目需求选择合适的版本,并了解其API和文档,以确保应用程序的安全和正确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值