ssl_ciphers 配置详解

天翼云开发者社区
• 阅读 4

本文分享自天翼云开发者社区《ssl_ciphers 配置详解》.作者:李****壮

一、配置方式

ssl_ciphers ciphers; 默认值:ssl_ciphers HIGH:!aNULL:!MD5; 上下文:http,server

作用:设置服务器建立与客户端请求https连接时,服务器可支持的ssl加密套件,可避免使用不安全的过时的加密算法。ssl_ciphers配置项的可选值由nginx编译时,引用的openssl组件 的ciphers定义。不同版本的openssl组件,可支持的加密套件也有所区别。

二、可选值详解

ssl_ciphers指令取值依赖于openssl库,因此可以直接用openssl工具来更方便的查看加密套件,验证取值。指令如下:

openssl ciphers [-v] [-ssl2] [-ssl3] [-tls1] [cipherlist]

-v:详细列出所有加密套件。包括ssl版本(SSLv2、SSLv3以及 TLS)、密钥交换算法、身份验证算法、对称算法、摘要算法。
-ssl2:只列出SSLv2使用的加密套件。
-ssl3:只列出SSLv3使用的加密套件。
-tls1:只列出tls使用的加密套件。
cipherlist:列出一个cipher list的详细内容。用此项能列出所有符合规则的加密套件,如果不加-v选项,它只显示各个套件名字;

2.1 算法列表(cipherlist)格式

算法列表包含一个或多个冒号隔开的。逗号或空格是可接受的分隔符,但是冒号是普遍使用的。

真实的算法字符串可以是不同算法组件的组合。也可以包含一个简单的算法组件,例如AES256-RSA256。

之后示例中B<>表示强调<>内的内容是算法列表符号,真实值为<>内的内容。

一个算法组件包含某几个算法,或者算法套件的几个类型值。例如B代表所有的算法套件中的摘要算法为SHA1;B代表所有的SSL v3相关的算法。

一个算法组件可以用B<+>字符把简单的算法字符连接起来。这是一个符合逻辑的B操作。例如,B<SHA1+DES>代表所有同时包含SHA1和DES的算法套件。可以在每个算法字符串之前使用字符B<!>、B<->或 B<+>。

如果使用字符B<!>,则从算法列表中删除该算法。根据明确的规定,删除了的算法将不会再出现。

如果使用字符B<->,则从算法列表中删除该算法。但是可以通过后面的选项将一个或所有的算法可以被再次添加。

如果使用字符B<+>,则将该算法移到算法列表的末尾。这个选项不会添加任何新的算法,它只是紧紧的移动匹配的已经存在的算法。

如果没有上述字符被提出,则该字符串则作为一个算法列表中的一部分则仅仅被解释。如果这个列表包含的算法已经被删除,则他们将被忽略:因为他们不会被移到列表的末尾。

此外,算法字符串B<@STRENGTH>可以被用于到分类,可以让符合条件的算法按加密算法的长度分类(输出时会聚合在一起)。

2.2 取值

下面是合法的算法字符串以及他们的详细解释:

B:默认的算法列表。这个在编译的时候决定,OpenSSL1.0.0以上的版本默认的是BALL:!aNULL:!eNULL。这个必须是第一个有详细说明的算法字符串。

B:这个算法包含B,但没有被默认激活。目前它的值是B。需要注意的是这个规则不包括B(它不被包含在B中)。

B:所有的算法套件但是不包括B算法,因为B算法必须被明确的激活。作为OpenSSL的一部分,B算法套件被合理的被设置为默认算法套件。

B:这个算法套件不激活B,目前仅仅包含B算法。

B:"high"加密算法套件。目前意味着密钥长度值大于128位,目前一些算法套件是128字节的密钥。

B:"medium"加密算法套件。目前一些算法套件是128字节的加密。

B:"low"加密算法套件。目前使用64位或56位密钥的加密算法,但是不包括export系列的算法套件。

B, B:export系列的加密算法。包含40字节和56字节的算法。

B:40字节的加密算法。

B:56字节的加密算法。在OpenSSL0.9.8c版本以后后面的版本中56字节的export算法是空的,除非OpenSSL明确的表明支持实验性的算法。

B,B:"NULL"类型的算法,它表明不用进行任何加密操作。如果要显示包含的数据则存在一些安全风险。

B:算法套件中没有验证算法。当前它是一个匿名的DH算法。这些算法套件是易受到中间攻击的,于是不建议使用它。

B, B:用RSA密钥来进行密钥交换。

B:使用短暂的DH密钥协议。

B, B:算法套件使用DH密钥协议和CA分别用RSA和DSS密钥签名的DH证书。目前没有进行运用。

B:用RSA密钥来执行验证操作。证书携带RSA密钥。

B, B:用DSS密钥来执行验证操作。证书携带DSS密钥。

B:用DH密钥来执行验证操作。证书携带DH密钥。目前没有进行运用。

B, B, B, B:用FORTEZZA密钥来进行密钥交换、验证、加密。目前没有进行运用。

B, B, B:TLS v1.0, SSL v3.0 or SSL v2.0算法套件。

B:算法套件使用DH算法,包括匿名的DH。

B:匿名的DH算法套件。

B:算法套件使用AES算法。

B:算法套件使用CAMELLIA算法。

B<3DES>:算法套件使用3des算法。

B:算法套件使用des算法。

B:算法套件使用rc4算法。

B:算法套件使用rc2算法。

B:算法套件使用IDEA算法。

B:算法套件使用SEED算法。

B:算法套件使用MD5算法。

B, B:算法套件使用SHA算法。

B:算法套件使用GOST R 34.10 (either 2001 or 94)来执行验证操作(需要一个支持GOST算法的硬件引擎)。

B:算法套件使用GOST R 34.10-94来执行验证操作(注意R 34.10-94的标准已经过期了,建议使用GOST R 34.10-2001)。

B:用VKO 34.10来执行密钥交换操作。在RFC4357中指定。

B:算法套件,用基于GOST R 34.11-94的HMAC算法。

B:算法套件,用GOST 28147-89摘要算法来代替HMAC。

2.3 实测

cipherlist部分用单引号包含字符串,避免!被 bash转义

ssl_ciphers 配置详解

Kx 密钥交换算法 :用来协商回话密钥 Au 验证算法 :用来验证服务端身份 Enc对称加密算法:加密消息 Mac摘要算法:防消息篡改

ssl_ciphers 配置详解

支持RSA的所有算法套件

ssl_ciphers 配置详解

ssl_ciphers 默认取值包含的算法

三、验证方式

通过以上说明,可以配置一条符合客户需求的加密套件取值,之后就需要进行算法的验证,看是否符合客户需求

可以通过如下命令,请求nginx,看加密条件是否符合预期

openssl s_client -cipher -connect ip:port -servername

ssl_ciphers 配置详解

如上说明,服务器不支持该算法套件

ssl_ciphers 配置详解

如上说明 本地的openssl工具不包含该算法套件,可能属于淘汰已废弃,也可能算法属于实验性算法,未包含。注意openssl工具与nginx使用的openssl组件,可能版本不一致,包含的算法套件有所差别。

ssl_ciphers 配置详解

如上表示服务器支持该加密套件

点赞
收藏
评论区
推荐文章
使用element-ui 的上传组件upload完成自定义上传到天翼云oss云服务器
本文分享自天翼云开发者社区@《》,作者:我是小朋友首先配置天翼云,如下操作1、要求在使用OOS之前,首先需要在www.ctyun.cn注册一个账号(Account)。创建AccessKeyId和AccessSecretKey。AccessKeyId和Acc
虚拟主机和云服务器的区别
本文分享自天翼云开发者社区@《》,作者:AE86上山了虚拟主机和云服务器的区别1、云服务器可支持弹性扩展,按需付费,而虚拟主机不支持2、云服务器需要手动配置环境,虚拟主机无须配置环境3、云服务器是独享资源,虚拟主机的资源是共享的4、云服务器可远程桌面进行管
PostgreSQL:psql 介绍
本文分享自天翼云开发者社区《》,作者:周平psql命令是与PostgreSQL服务器交互的客户端程序,要登录到数据库服务器,需要使用psql客户端工具或者第三方客户端工具如PostgreSQLforNavicat,pgAdmin,Visualizer等等。
Nginx的ngx_thread_pool模块解析:提升性能与可伸缩性
本文分享自天翼云开发者社区《》.作者:云海Nginx是一个备受欢迎的开源Web服务器和反向代理服务器,以其出色的性能和可伸缩性而著称。在处理高并发请求时,Nginx的ngxthreadpool模块发挥了关键作用,允许您有效地利用多核CPU,提高并发处理性能
openresty中使用ngx.sleep(0)防止worker进程阻塞
本文分享自天翼云开发者社区《》.作者:小谢不用谢1.ngx.sleep(0)的工作原理在OpenResty中,ngx.sleep(0)函数的作用是让当前的Lua协程主动放弃CPU执行权,以便Nginx能够及时处理其他并发请求和I/O操作。具体来说,调用ng
ngx.location.capture()变量继承
本文分享自天翼云开发者社区《》.作者:luckylyw通过几个例子,简要分析variable与ctx在主请求与子请求中的关系。copyallvars&shareallvarsserverlisten:::80;https配置http访问端口v6格式li
boringssl中0-RTT的错误码
本文分享自天翼云开发者社区《》.作者:沈扬在TLS协议中,0RTT(零往返时间)是指在某些情况下,客户端可以在第一个往返(RTT)中就开始发送加密的应用数据,而不需要等待完整的TLS握手完成。这种机制允许客户端在重新连接到服务器时,利用之前会话中缓存的信息
core文件生成位置及命名
本文分享自天翼云开发者社区《》.作者:李壮三级标题一、core文件的生成1.1/proc/sys/kernel/corepattern系统文件/proc/sys/kernel/corepattern记录core文件格式及保存目录。可以带绝对目录,或者相对目
openresty共享内存的使用
本文分享自天翼云开发者社区《》.作者:王兰在OpenResty中,ngx.shared用于访问共享内存区域,这在处理高并发请求时非常有用。以下是一些常见的使用场景和示例代码。首先,需要在Nginx配置文件中定义一个共享内存区域。例如,在http块中添加以下
升级curl版本,及升级后引起的动态库链接不正常问题的解决
本文分享自天翼云开发者社区《》.作者:李壮服务器使用的curl,可能版本较低,无法支持请求ipv6地址等新功能,此时,就需要升级curl版本。一般的云源提供的版本本身较低,需要指定特定的云源进行升级。升级后,部分机器会产生动态库链接不正确的问题,虽然cur
天翼云开发者社区
天翼云开发者社区
Lv1
天翼云是中国电信倾力打造的云服务品牌,致力于成为领先的云计算服务提供商。提供云主机、CDN、云电脑、大数据及AI等全线产品和场景化解决方案。
文章
999
粉丝
16
获赞
40