use*_*466 1 ssl openssl certificate
我需要将以下 SAN 添加到证书中:
oid:1.2.3.4.5.5
Run Code Online (Sandbox Code Playgroud)
我正常的证书创建过程是生成一个openssl.cnf文件,然后用这个文件生成一个csr(证书签名请求),然后用我自己的CA从csr生成一个证书。
.cnf 文件是一个纯文本文件,其中包含一个部分,描述了我希望包含在 csr 和最终 crt 中的所有 SAN。该部分如下所示:
...
[san]
DNS.1 = foo.bar
DNS.2 = baz.foobar
IP.1 = 1.1.1.1
IP.2 = 2.2.2.2
...
Run Code Online (Sandbox Code Playgroud)
我尝试以 3 种不同的方式插入 OID 条目:
attempt 1) OID.1 = 1.2.3.4.5.5
attempt 2) DNS.3 = 1.2.3.4.5.5
attempt 3) IP.3 = 1.2.3.4.5.5
Run Code Online (Sandbox Code Playgroud)
1) 尝试生成证书时出现错误,表明OID
无法识别前缀。使用 2) 和 3) 我能够生成 crt,但是当我将它放置到位时,不支持 SAN oid:1.2.3.4.5.5。
所以,我想知道将此类和条目添加到 openssl.cnf 文件的主题备用名称部分的正确语法是什么。
干杯!
根据 Steffen Ullrich 的回答,此版本在完整示例中正确指定了 OID 标识符:
subjectAltName=@san
[san]
DNS.1=foo.example.com
DNS.2=bar.example.com
RID.1=1.2.3.4.5.5
Run Code Online (Sandbox Code Playgroud)
或者,在一行上执行:
subjectAltName=DNS:foo.example.com,DNS:bar.example.com,RID:1.2.3.4.5.5
Run Code Online (Sandbox Code Playgroud)
这在与https://security.stackexchange.com/a/91556结合使用以将-config
选项传递给 CLI 而不使用 .cnf 文件时特别有用。