ssl - 如何在 NGINX 中禁用 TLS 1.0?

标签 ssl nginx configuration ssl-certificate tls1.2

在 nginx.conf 的服务器级别上,我有:

ssl_protocols  TLSv1.1 TLSv1.2;
ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:AES128-SHA:AES256-SHA:AES:CAMELLIA:DES-CBC3-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!aECDH:!EDH-DSS-DES-CBC3-SHA:!EDH-RSA-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA';  

但无论如何,当我运行时:

openssl s_client -connect www.example.com:443 -tls1

我获得了 TLS 1.0 的有效连接。 SSLLabs 将站点的 nginx 设置为 A,但使用 TLS 1.0 。

root@qa-ebd:~# openssl version -a
OpenSSL 1.0.2j  26 Sep 2016
built on: reproducible build, date unspecified
platform: linux-x86_64
options:  bn(64,64) rc4(16x,int) des(idx,cisc,16,int) idea(int) blowfish(idx) 
compiler: gcc -I. -I.. -I../include  -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -Wa,--noexecstack -m64 -DL_ENDIAN -O3 -Wall -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5 -DOPENSSL_BN_ASM_GF2m -DRC4_ASM -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DMD5_ASM -DAES_ASM -DVPAES_ASM -DBSAES_ASM -DWHIRLPOOL_ASM -DGHASH_ASM -DECP_NISTZ256_ASM
OPENSSLDIR: "/usr/local/openssl"
root@qa-ebd:~# 
root@qa-ebd:~# 
root@qa-ebd:~# nginx -V
nginx version: nginx/1.10.2
built by gcc 4.8.4 (Ubuntu 4.8.4-2ubuntu1~14.04.3) 
built with OpenSSL 1.0.1f 6 Jan 2014
TLS SNI support enabled
configure arguments: --prefix=/opt/nginx  --with-http_ssl_module   --with-http_geoip_module --with-http_gzip_static_module  --with-http_stub_status_module --with-pcre 

最佳答案

打开 nginx 配置文件(/etc/nginx/nginx.conf)并在 http 部分添加以下行:

ssl_protocols TLSv1.1 TLSv1.2;

这将为该服务器中的所有应用程序禁用 TLS1.0。您可以使用以下 openssl 命令进行测试:

openssl s_client -connect example.com:443 -tls1

你应该得到类似的输出:

CONNECTED(00000003)
write:errno=104
---
no peer certificate available
---
No client certificate CA names sent
---
SSL handshake has read 0 bytes and written 0 bytes
---

关于ssl - 如何在 NGINX 中禁用 TLS 1.0?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40362244/

相关文章:

spring - 用于验证 Spring 配置的 Maven 插件?

ruby-on-rails - 连接由对等方重置 - 打开 URL 时的 SSL_connect

node.js - 如何让 SSL 很好地处理非 SSL 协议(protocol)数据

angularjs - 向 logstash 发出发布请求时出现 CORS 错误

c# - ASP.net Core 2.0 中的 appsettings.json 预览配置 GetSection null

javascript - 对于用于 HTML、CSS 和 JavaScript 开发的理想 Sublime Text 2 配置,您有何建议?

multithreading - Asio SSL 流线程安全

ruby - 配置 Vagrant CA 证书

c++ - 如何使用 C++ 驱动程序将两个客户端 IP 连接到同一个 mongodb

WordPress 3.0 和 nginx - 永久链接,404 问题