ssl - 如何生成由对称 key 加密的 PKCS8 私钥?

标签 ssl cryptography openssl des pkcs#8

如果我尝试使用 OpenSSL 命令行生成 3TDES 加密的 PKCS 8 key :

openssl genrsa 512 | openssl pkcs8 -topk8 -v2 des-ede3-cbc

我得到:

Enter Encryption Password:

如果我想使用实际 key 而不是从密码派生的 key 对其进行加密怎么办?

PKCS8 RFC 没有说明必须使用哪种算法来创建 key block 。它确实以 PKCS5 算法为例。有没有办法使用 OpenSSL 创建由 DES key 加密的 PKCS8 key ?如果不是,它是否只是不受 OpenSSL 支持,或者这是一件非常不标准的事情?

这是一个通过 OpenSSL 命令行(密码“test”)使用基于密码的加密创建的示例:

 0:d=0  hl=4 l= 422 cons: SEQUENCE          
 4:d=1  hl=2 l=  64 cons:  SEQUENCE          
 6:d=2  hl=2 l=   9 prim:   OBJECT            :PBES2
17:d=2  hl=2 l=  51 cons:   SEQUENCE          
19:d=3  hl=2 l=  27 cons:    SEQUENCE          
21:d=4  hl=2 l=   9 prim:     OBJECT            :PBKDF2
32:d=4  hl=2 l=  14 cons:     SEQUENCE          
34:d=5  hl=2 l=   8 prim:      OCTET STRING      
   0000 - 34 28 48 ce 80 65 2e 49-                          4(H..e.I
44:d=5  hl=2 l=   2 prim:      INTEGER           :0800
48:d=3  hl=2 l=  20 cons:    SEQUENCE          
50:d=4  hl=2 l=   8 prim:     OBJECT            :des-ede3-cbc
60:d=4  hl=2 l=   8 prim:     OCTET STRING      
   0000 - 87 9a 4b b1 4a 9a 5d 2a-                          ..K.J.]*
70:d=1  hl=4 l= 352 prim:  OCTET STRING      
   0000 - 1a 93 74 14 57 96 80 ca-68 2f 06 82 a4 3c c5 bb   ..t.W...h/...<..
   0010 - 2e 32 81 28 89 d9 71 8c-f3 20 4c 3d d4 7a 8c 17   .2.(..q.. L=.z..
   0020 - 13 fd 8e bd 59 54 dd 17-4d 72 12 dd 24 71 af 39   ....YT..Mr..$q.9
   0030 - 16 64 3f 11 63 4b 36 b4-cf 5d 42 a7 4a 7e be 26   .d?.cK6..]B.J~.&
   0040 - b1 8e 60 2a 28 b8 21 f8-a6 0e 54 93 28 bb 46 e9   ..`*(.!...T.(.F.
   0050 - c9 45 1f 5a 91 17 d8 a0-06 b0 c4 1b c0 2f ee e1   .E.Z........./..
   0060 - fd d0 3b 44 23 2c 98 ab-ea e9 3e 2e f3 ce 14 04   ..;D#,....>.....
   0070 - f7 ab 4e 1a f2 f7 70 b0-02 51 aa cd 86 ae 97 f1   ..N...p..Q......
   0080 - 66 9f 75 72 06 2e a3 90-38 50 44 88 b0 8a c1 26   f.ur....8PD....&
   0090 - 57 1b 21 95 7b f9 af 66-c4 ac 4e 68 c4 32 cb 16   W.!.{..f..Nh.2..
   00a0 - 78 1c 55 d1 c1 b6 93 1c-15 ab 92 32 2c 6c 8d 2f   x.U........2,l./
   00b0 - 34 ba 09 a1 ac 4b 7a d0-86 cd 68 0d b8 67 2f 20   4....Kz...h..g/ 
   00c0 - 91 c7 79 64 0a cd f7 68-5f c3 08 ea 1a 4f d1 b8   ..yd...h_....O..
   00d0 - c6 ac ff ff a1 c0 38 e1-32 22 f4 76 60 60 6f 9d   ......8.2".v``o.
   00e0 - c0 07 32 ec 35 31 7a c5-d4 f3 0d cc 76 f4 f1 d2   ..2.51z.....v...
   00f0 - 77 79 11 4d 60 62 9b 23-56 23 a3 7d 9d 64 96 b0   wy.M`b.#V#.}.d..
   0100 - c4 c5 12 7f d4 87 07 fa-c4 8a 0a 03 9e 21 70 d8   .............!p.
   0110 - eb 8a 6b 24 ee 58 bc 23-82 23 ac 90 36 9a ab a0   ..k$.X.#.#..6...
   0120 - 9f c9 8d f5 07 f4 c6 53-6d 00 fd b3 9d 5b e9 cd   .......Sm....[..
   0130 - c4 f6 27 89 55 98 f0 bc-05 31 75 6a 2d d5 12 b1   ..'.U....1uj-...
   0140 - 41 9f e5 6b 45 6c 12 7d-02 ab b6 e6 78 6c 62 f3   A..kEl.}....xlb.
   0150 - d2 9d c1 29 de 98 22 ba-98 b5 47 7d 38 ff 82 50   ...).."...G}8..P

这是我手动创建的 PKCS8 key ,通过使用 TDES CBC 和全 0 的三倍长度 key (IV 5F218F117C86CEE1) 来加密“PrivateKeyInfo”ASN1 结构,然后将该有效负载放入“EncryptedPrivateKeyInfo”ASN1 结构中:

 0:d=0  hl=4 l= 378 cons: SEQUENCE          
 4:d=1  hl=2 l=  20 cons:  SEQUENCE          
 6:d=2  hl=2 l=   8 prim:   OBJECT            :des-ede3-cbc
16:d=2  hl=2 l=   8 prim:   OCTET STRING      
   0000 - 5f 21 8f 11 7c 86 ce e1-                          _!..|...
26:d=1  hl=4 l= 352 prim:  OCTET STRING      
   0000 - c1 dc 29 07 0d 4b 48 73-8a 6f 98 04 12 69 e0 ca   ..)..KHs.o...i..
   0010 - a6 d2 f3 94 01 ba aa c8-72 da d4 cb 99 92 96 cd   ........r.......
   0020 - f0 7f 92 b0 c9 4b 81 02-c6 28 a9 3a 26 68 44 e3   .....K...(.:&hD.
   0030 - 6a 52 4b a6 02 0d ef 72-07 d2 23 a4 0e c3 ab 2c   jRK....r..#....,
   0040 - 9c d7 8c 92 3c df 01 41-a5 b9 90 fc 91 f6 c3 6a   ....<..A.......j
   0050 - 83 02 2a e9 71 59 a4 70-36 16 45 be a6 2a c8 e7   ..*.qY.p6.E..*..
   0060 - 84 cc ce a9 fa 1f a0 60-e9 26 a2 d7 41 bb 3c 1a   .......`.&..A.<.
   0070 - 1b a4 47 21 dc 51 4d f7-ed dd 2a 8c 5f e6 68 9e   ..G!.QM...*._.h.
   0080 - f2 60 c1 79 bc d4 e7 0d-4b 90 4b 80 30 5b 30 f8   .`.y....K.K.0[0.
   0090 - 49 8f 7f 82 05 f7 d3 4d-51 f7 5d ff e8 7c c4 ff   I......MQ.]..|..
   00a0 - d9 ad a3 f9 33 08 22 29-9e da d5 ee 67 6a 68 a4   ....3.")....gjh.
   00b0 - 80 29 8f 6a d9 2b ef d5-50 87 69 9a 66 da 3e 78   .).j.+..P.i.f.>x
   00c0 - 0a 5d 9d 40 58 ea a3 88-92 62 d5 7c 72 05 f4 4d   .].@X....b.|r..M
   00d0 - 01 ca 8d fb 0b af 71 25-d8 1b a6 03 4d 74 f8 ac   ......q%....Mt..
   00e0 - 7d 77 44 08 e5 84 0d fb-15 c3 f7 d4 4c e7 50 b3   }wD.........L.P.
   00f0 - 08 96 9a 33 3c 74 05 ec-3d 8b 19 01 ba 04 d0 ab   ...3<t..=.......
   0100 - 47 32 6a d8 09 9b 0e 0e-58 f5 34 5f 8f 63 18 12   G2j.....X.4_.c..
   0110 - 22 a5 f7 e0 af 09 ed 16-22 2c 35 4a 8f 55 f3 22   ".......",5J.U."
   0120 - aa b1 e0 f4 27 df 45 ef-3b 04 08 19 89 67 dd 17   ....'.E.;....g..
   0130 - 47 13 55 3f 9d 0a a3 80-4d 6a 49 90 e9 83 90 ad   G.U?....MjI.....
   0140 - 1b 49 2f c1 1f c5 8b db-03 38 a4 13 03 ad fe 99   .I/......8......
   0150 - 1d 75 e7 b1 2f 83 ad e4-42 74 44 06 38 cb bd c4   .u../...BtD.8...

据我所知,我的 key block 符合 RFC。然而,由于 OpenSSL 无法生成类似的东西,而且我找不到任何类似类型的 PKCS8 加密的测试向量,我担心这种格式在某种程度上是不标准的。

有谁知道以这种方式(使用基于非密码的加密方案)构建 PKCS8 key 是否正确?

PKCS8 RFC https://www.rfc-editor.org/rfc/rfc5208

未加密的 PKCS8 私钥:

PrivateKeyInfo ::= SEQUENCE {
    version Version,
    privateKeyAlgorithm AlgorithmIdentifier {{PrivateKeyAlgorithms}},
    privateKey PrivateKey,
    attributes [0] Attributes OPTIONAL }

被加密并放入加密的PKCS8结构中:

EncryptedPrivateKeyInfo ::= SEQUENCE {
    encryptionAlgorithm AlgorithmIdentifier {{KeyEncryptionAlgorithms}},
    encryptedData EncryptedData }

我不确定这些空的算法标识符定义是做什么用的

PrivateKeyAlgorithms ALGORITHM-IDENTIFIER ::= {
     ... -- For local profiles
}

KeyEncryptionAlgorithms ALGORITHM-IDENTIFIER ::= {
     ... -- For local profiles
}

X509 RFC https://www.rfc-editor.org/rfc/rfc5280

这定义了算法标识符字段

AlgorithmIdentifier  ::=  SEQUENCE  {
    algorithm               OBJECT IDENTIFIER,
    parameters              ANY DEFINED BY algorithm OPTIONAL  }

TDES CBC 算法标识符的加密消息语法:http://www.ietf.org/rfc/rfc3370.txt

The AlgorithmIdentifier parameters field MUST be present, and the
parameters field must contain a CBCParameter:

CBCParameter ::= IV

IV ::= OCTET STRING  -- exactly 8 octets

最佳答案

这是对 OpenSSL 邮件列表中相同问题的回复:

http://marc.info/?l=openssl-users&m=137106970116394&w=2

使用任何密码的 AlgorithmIdentifierencryptionAlgorithm 字段创建 PKCS8 key block 似乎是有效的。

"[T]he standard does not restrict the possible values, it may very well be possible that someone somewhere has a PKCS#8 implementation which accepts a value which does not refer to a password based encryption scheme."

关于ssl - 如何生成由对称 key 加密的 PKCS8 私钥?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16947680/

相关文章:

java - Kafka java消费者SSL握手错误: java. security.cert.CertificateException:不存在主题替代名称

java - 使用基于 Java Key Store 别名的单个证书

ssl - 在 Firefox 中,curl 不验证带有 --cacert 传递的导出站点证书的证书

java - Android 4.4解密错误

security - 如何从 EXTERNAL AUTHENTICATE 命令 apdu 计算 C-MAC?

ssl - 在 C 客户端/服务器应用程序上重用 SSL session

ssl - 为什么此 SSL 连接突然终止

android - 该软件激活/许可证验证方案(从加密角度、技术角度)合理性如何?

仅从移动设备显示 SSL 错误

c - EVP 加密核心已转储