A última vulnerabilidade
OpenSSL OpenSSL lançou oficialmente um aviso de risco de vulnerabilidade de negação de serviço, o número de vulnerabilidade é CVE-2020-1971
Detalhes da vulnerabilidade
OpenSSL é um pacote de biblioteca de software de código aberto, o aplicativo pode usar este pacote para proteger dados, evitar roubo, ouvir **, enquanto a outra extremidade está conectada para confirmar a identidade da pessoa. Este pacote é amplamente utilizado em servidores web na Internet.
Quando o OpenSSL está processando EDIPatyName (identificador de tipo X.509 GeneralName), há uma desreferência do ponteiro nulo, que causa a falha do programa e a negação de serviço. A pessoa *** pode acionar a vulnerabilidade construindo um processo de verificação de certificado especial e fazer com que o servidor negue o serviço.
Alto nível de risco
Risco de
vulnerabilidade Vulnerabilidade explorada pode causar negação de serviço
Versão afetada
OpenSSL: 1.0.2-1.0.2w
OpenSSL: 1.1.1-1.1.1h
Versão segura
OpenSSL: 1.1.1i
OpenSSL: 1.0.2x
Sugestão de reparo
para atualizar o OpenSSL para 1.1.1i, 1.0.2x ou a versão mais recente
[Observações]: É recomendável que você faça um bom trabalho de backup de dados antes de atualizar para evitar acidentes
Referência de vulnerabilidade
https://www.openssl.org/news/vulnerabilities-1.1.1.html#CVE-2020-1971
https://www.openssl.org/news/vulnerabilities-1.0.2.html#CVE-2020-1971
- O pacote rpm OpenSSL1.1.1i
pode ser automaticamente empacotado diretamente usando o seguinte script de shell.
#!/bin/bash
set -e
set -v
if [[ ! -f "/root/openssl-1.1.1i.tar.gz" ]];then
wget -O /root/openssl-1.1.1i.tar.gz https://www.openssl.org/source/openssl-1.1.1i.tar.gz
fi
mkdir ~/openssl && cd ~/openssl
yum -y install \
curl \
which \
make \
gcc \
perl \
perl-WWW-Curl \
rpm-build
# Get openssl tarball
if [[ ! -f "./openssl-1.1.1i.tar.gz" ]];then
cp /root/openssl-1.1.1i.tar.gz ./
fi
# SPEC file
cat << 'EOF' > ~/openssl/openssl.spec
Summary: OpenSSL 1.1.1i for Centos
Name: openssl
Version: %{?version}%{!?version:1.1.1i}
Release: 1%{?dist}
Obsoletes: %{name} <= %{version}
Provides: %{name} = %{version}
URL: https://www.openssl.org/
License: GPLv2+
Source: https://www.openssl.org/source/%{name}-%{version}.tar.gz
BuildRequires: make gcc perl perl-WWW-Curl
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root
%global openssldir /usr/local/openssl
%description
OpenSSL RPM for version 1.1.1i on Centos
%package devel
Summary: Development files for programs which will use the openssl library
Group: Development/Libraries
Requires: %{name} = %{version}-%{release}
%description devel
OpenSSL RPM for version 1.1.1i on Centos (development package)
%prep
%setup -q
%build
./config --prefix=%{openssldir} --openssldir=%{openssldir}
make
%install
[ "%{buildroot}" != "/" ] && %{__rm} -rf %{buildroot}
%make_install
mkdir -p %{buildroot}%{_bindir}
mkdir -p %{buildroot}%{_libdir}
ln -sf %{openssldir}/lib/libssl.so.1.1 %{buildroot}%{_libdir}
ln -sf %{openssldir}/lib/libcrypto.so.1.1 %{buildroot}%{_libdir}
ln -sf %{openssldir}/bin/openssl %{buildroot}%{_bindir}
%clean
[ "%{buildroot}" != "/" ] && %{__rm} -rf %{buildroot}
%files
%{openssldir}
%defattr(-,root,root)
/usr/bin/openssl
/usr/lib64/libcrypto.so.1.1
/usr/lib64/libssl.so.1.1
%files devel
%{openssldir}/include/*
%defattr(-,root,root)
%post -p /sbin/ldconfig
%postun -p /sbin/ldconfig
EOF
mkdir -p /root/rpmbuild/{BUILD,RPMS,SOURCES,SPECS,SRPMS}
cp ~/openssl/openssl.spec /root/rpmbuild/SPECS/openssl.spec
mv openssl-1.1.1i.tar.gz /root/rpmbuild/SOURCES
cd /root/rpmbuild/SPECS && \
rpmbuild \
-D "version 1.1.1i" \
-ba openssl.spec
# Before Uninstall Openssl : rpm -qa openssl
# Uninstall Current Openssl Vesion : yum -y remove openssl
# For install: rpm -ivvh /root/rpmbuild/RPMS/x86_64/openssl-1.1.1i-1.el7.x86_64.rpm --nodeps
# or rpm -Uvh openssl-1.1.1i-1.el7.x86_64.rpm --nodeps --force
# Verify install: rpm -qa openssl
# openssl version
Eu usei:
rpm -Uvh openssl-1.1.1i-1.el7.x86_64.rpm --nodeps --force