LibreSSL是什么

Fanly 2019-07-11 10:11:45
问答

LibreSSL是OpenSSL加密软件库的分支,是一个安全套接层和传输层安全协议的开源实现。在OpenSSL爆出心脏出血安全漏洞之后创立了LibreSSL,重构OpenSSL代码,以提供一个更安全的替代品。

LibreSSLOpenSSL 加密软件库的一个分支,是一个安全套接层和传输层安全协议的开源实现。在 OpenSSL 爆出心脏出血安全漏洞之后,一些 OpenBSD 开发者于 2014 年 4 月创立了 LibreSSL,目标是重构 OpenSSL 的代码,以提供一个更安全的替代品。

libressl

LibreSSL 复刻自 OpenSSL 库的 1.0.1g 分支,它将遵循 OpenBSD 基金会在其他项目所使用的安全指导原则。

历史

在 OpenSSL 爆出心脏出血漏洞后的一周之内,OpenBSD 开发团队便决定自行维护一个 OpenSSL 分支。开发团队于 2014 年 4 月 11 日注册 libressl.org 域名,该项目于 2014 年 4 月 22 日公布。

OpenBSD 开发团队随即开始清理 OpenSSL 的代码,在第一周,LibreSSL 开发团队删去了 90000 多行的代码。一些陈旧或无用代码被移除,同时对一些比较罕见的操作系统的支持也被移除。LibreSSL 最初的目标平台是 OpenBSD 5.6,但当代码稳定之后,还移植至其他平台。截至 2014 年 4 月,该项目仍在寻求“稳定的”外部资金支持。

变化详情

内存相关

一些较显着和重要的变化包括更换自定义的内存访问调用为标准函数(例如 strlcpy、calloc、asprintf、reallocarray 等)。这有助于在将来用更先进的内存调试器,或通过观察程序的崩溃情况来发现缓存溢出等错误。CVS 提交日志中也记录了对潜在双重释放内存的修复(包括空指针值的显式分配)。

加密算法

原本不安全的种子生成方法(由内核原生提供)被移除,以确保随机数种子是通过安全的随机数生成器产生的。又新加入了一系列算法,包括 ChaCha20-Poly1305 等。

其他改动

加入了的完整性检查,以检查长度参数、无符号到有符号变量的赋值、指针值/方法返回值等数据的有效性。启用了一些使之更加安全的编译器选项和标志(-Wuninitialized,-Werror 等),这有助于发现潜在问题。为遵循良好的编程风格,项目也提高了代码可读性并清理空白字符,使之匹配 BSD 的代码风格(KNF)。移除了不必要或不安全的宏和变量;移除了未使用的或旧的程序集、应用程序、演示及文档文件/代码(Perl 脚本、C 语言文件等)。移除了对 FIPS 140-2 的支持、不安全的算法 Dual EC DRBG 及旧的协议/加密器(SSLv2)。

0个人收藏 收藏

相关推荐

  • OpenSSL

    OpenSSL是什么软件

    OpenSSL是一个开放源代码的软件库包,应用程序可以使用这个包来进行安全通信,避免窃听,同时确认另一端连线者的身份。广泛被应用在互联网的网页服务器上。 主要库以C语言写成,实现基本的加密功能及SSL与TLS协议。
  • HTTPS

    内网IP如何实现HTTPS协议

    内网环境中实现HTTPS协议需要生成SSL/TLS证书,部署到服务器,并确保设备信任该证书。虽然内网相对安全,但采用HTTPS可进一步保护数据传输的安全性和完整性,通过使用私有CA签发证书或导入公有CA证书,组织可以确保内部通信的加密和身份验证,防止数据泄露和中间人攻击。
  • Kubernetes

    如何在Kubernetes中管理和更新证书

    Kubernetes中证书为组件间通讯提供了安全保障。除了Kubernetes内建的证书API和管理器外,手动更新证书需要生成新证书、更新配置并重启组件。为简化流程Cert-manager自动颁发和更新证书,并支持外部CA集成。
  • linux kernel Linux 内核升级 Linux 升级

    如何升级Linux内核

    升级Linux内核是确保系统性能、安全性和硬件兼容性的重要步骤。首先备份数据,然后下载并解压新内核源代码。安装编译工具,配置内核选项,编译和安装内核。更新引导加载程序后,重启系统。在测试和故障排除后,确保一切正常工作。选择适合您需求的稳定版本,以确保系统稳定性。
  • EasePi ARS2 软路由

    软路由怎么使用OpenVPN异地组网

    软路由使用OpenVPN异地组网需要先安装好OpenWrt软路由系统,然后通过OpenWrt安装OpenVPN,安装完成后,我们需要创建一个OpenVPN配置文件,配置文件中包含我们需要连接的OpenVPN服务器的信息,比如服务器地址、端口号、证书等等。
  • 邮件服务器 email server

    公司如何搭建邮件服务器

    首先我们需要选择邮件服务器软件,目前市面上有很多种邮件服务器软件,比如Exim、Postfix、Sendmail等,以Postfix为例按照文章中的步骤进行操作,就可以顺利完成邮件服务器的搭建。