SSL/TLS 协议信息泄露漏洞(CVE-2016-2183)修复(机器无外网)

前言

最近公司扫漏,发现 SSL/TLS 协议信息泄露漏洞:TLS是安全传输层协议,用于在两个通信应用程序之间提供保密性和数据完整性。 TLS, SSH, IPSec 协商及其他产品中使用的 IDEA、DES 及 Triple DES 密码或者 3DES 及 Triple 3DES 存在大约四十亿块的生日界,这可使远程攻击者通过 Sweet32 攻击,获取纯文本数据。让根据给出的建议进行漏洞加固,下面记录了没有外网 linux 服务器的修复过程。

加固建议

避免使用 IDEA、DES 和 3DES算法。

1、更新 OpenSSL 到最新版本。

2、对于 nginx、apache、lighttpd 等服务器禁止使用 DES 加密算法,主要是修改 conf 文件。

安装 openssl

下载最新版本 openssl

www.openssl.org/source/

通过 rz 命令或者 ftp 工具将压缩包上传到目标机器。

安装相关依赖

以下是需要的依赖包:

可以在有网络的机器上通过以下命令下载:

css 复制代码
yum install --downloadonly --downloaddir=存放路径 包名

不指定目录时 centos7 默认会存放在 /var/cache/yum/x86_64/7/base/packages/

或者通过 yumdownloader:

ini 复制代码
yumdownloader httpd php subversion mod_dav_svn # 指定目录(不指定为当前目录)
yumdownloader --destdir=存放路径 包名
yumdownloader --resolve --destdir=存放路径 包名 # 下载包同时下载相关依赖

在目标机器创建 yum-cache 目录,上传所有依赖

安装当前目录下的所有依赖:

复制代码
yum localinstall *.rpm

安装 openssl

解压缩并进入 openssl 目录:

bash 复制代码
tar xvf openssl-3.2.0.tar.gz 
cd ./openssl-3.2.0

编译部署:

bash 复制代码
./config --prefix=/usr/local/openssl
make && make install

备份:

bash 复制代码
mv /usr/bin/openssl /usr/bin/openssl.bak
mv /usr/include/openssl /usr/include/openssl.bak

创建软链接(如果失败可以用 ln -sf 强制执行):

bash 复制代码
ln -s /usr/local/openssl/bin/openssl   /usr/bin/openssl
ln -s /usr/local/openssl/include/openssl   /usr/include/openss

更新动态链接:

bash 复制代码
echo "/usr/local/openssl/lib">>/etc/ld.so.conf
ldconfig

测试:

复制代码
openssl version

遇到 ./openssl: error while loading shared libraries: libssl.so.3: cannot open shared object file: No such file or directory 错误:

查看 /usr/local/openssl/lib64 目录,发现有 libssl.so.3 库文件,但是 openssl 程序却找不到,openssl 程序会去 /usr/lib/ 路径下去寻找库文件。 于是,把 openssl 的库文件全部拷贝到 /usr/lib/ 路径中去:

bash 复制代码
cp -r /usr/local/openssl/lib64/* /usr/lib

或者编辑 /etc/ld.so.conf 文件并添加共享库文件所在的目录。例如在文件中添加:

vbnet 复制代码
/path/to/openssl/lib

更新动态链接库

复制代码
ldconfig

更新 nginx

查看已安装模块

运行 nginx -V 命令查看已经安装的 nginx 模块,configure arguments:后面表示当前已经安装的nginx模块,如果有就复制下来。

重新编译

在 nginx 安装目录重新编译 nginx:

javascript 复制代码
./configure --原来有的模块(如果有的话) --with-openssl=/usr/local/openssl && make && make install

编译遇到 make[1]: *** [/usr/local/ssl/.openssl/include/openssl/ssl.h] 相关的错误: 修改 nginx 编译时对 openssl 的路径选择,打开 nginx 安装目录下的 nginx-1.23.3/auto/lib/openssl/conf 文件,找到下面代码:

bash 复制代码
CORE_INCS="$CORE_INCS $OPENSSL/.openssl/include"
CORE_DEPS="$CORE_DEPS $OPENSSL/.openssl/include/openssl/ssl.h"
CORE_LIBS="$CORE_LIBS $OPENSSL/.openssl/lib/libssl.a"
CORE_LIBS="$CORE_LIBS $OPENSSL/.openssl/lib/libcrypto.a"
CORE_LIBS="$CORE_LIBS $NGX_LIBDL"

将路径改成已经安装的 openssl 路径,我的是:

bash 复制代码
CORE_INCS="$CORE_INCS $OPENSSL/include"
CORE_DEPS="$CORE_DEPS $OPENSSL/include/openssl/ssl.h"
CORE_LIBS="$CORE_LIBS $OPENSSL/lib64/libssl.a"
CORE_LIBS="$CORE_LIBS $OPENSSL/lib64/libcrypto.a"
CORE_LIBS="$CORE_LIBS $NGX_LIBDL

禁用算法

将以下的内容替换 nginx 443端口配置中的 ssl_ciphers 内容,禁用指定算法:

ruby 复制代码
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!3DES:!ADH:!RC4:!DH:!DHE:!IDEA:!DES;

重启 nginx

bash 复制代码
/usr/local/nginx/sbin/nginx -s reload

修改成功

总结

本文记录了机器在无外部网络情况下更新 OpenSSL,确保系统安全性的提升。解释了如何获取 OpenSSL 更新包、手动传输至目标机器并进行安装的具体过程,以及修改 Nginx 配置,确保 Nginx 能够正确地利用新版本的 OpenSSL。希望对类似的安全漏洞的修复工作提供帮助。

相关推荐
游九尘16 分钟前
服务器都是用的iis, 前端部署后报跨域,不是用同一个服务器 是前端项目的服务器做Nginx转发,还是后端项目的服务器做Nginx转发?
服务器·前端·nginx
三坛海会大神55519 分钟前
nginx中配置https详解:配置SSL/TLS证书
nginx·https·ssl
半桔1 小时前
【Linux手册】信号量与建造者模式:以 PV 操作保证并发安全,分步组装构建复杂对象
linux·运维·安全·建造者模式
网络之路Blog2 小时前
【实战中提升自己完结篇】分支篇之分支之无线、内网安全与QOS部署(完结)
网络协议·安全·网络之路一天·华为华三数通基础·网络设备管理·华为华三二三层交换机对接
✎﹏赤子·墨筱晗♪2 小时前
Nginx 配置 SSL/TLS 全指南:从安装到安全强化
nginx·安全·ssl
m0_464608262 小时前
Nginx SSL/TLS 配置
运维·nginx·ssl
独行soc2 小时前
2025年渗透测试面试题总结-60(题目+回答)
java·python·安全·web安全·adb·面试·渗透测试
wanhengidc3 小时前
云手机可以用来托管游戏吗?
运维·网络·安全·游戏·智能手机
FreeBuf_3 小时前
Spring Cloud Gateway WebFlux现cvss10分高危漏洞,可导致环境属性篡改
安全·web安全
grrrr_112 小时前
【工具类】Nuclei YAML POC 编写以及批量检测
网络·安全·web安全