【发布时间】:2020-09-16 08:00:41
【问题描述】:
我有一组用于测试的 RSA 密钥。我正在对 PKCS#12 进行增强。现有的 RSA 密钥都有密码,比如说“mypass”。我想生成三种类型的 PKCS#12 密钥:
- PKCS#12 信封上没有密码(如果你读到this 确实是空字符串)并且里面的 RSA 密钥上没有密码
- PKCS#12 信封上有密码,里面的 RSA 密钥没有密码
- PKCS#12 信封和内部 RSA 密钥上的密码
第一个选项类别有问题
在这里,我将 PEM 格式的源密钥复制到我的工作区并创建一个以字母 d 为前缀的解密版本。 $tkey 是 PEM 格式的输入键。
echo RSA keys PEM formatted
key=${name}.priv.rsa.pem
dkey=d${name}.priv.rsa.pem
pubkey=${name}.pub.rsa.pem
cp $tkey ./${key}
openssl rsa -in $key -passin pass:mypass -out $dkey -outform pem -passout pass:
我认为解密后的密钥上面没有密码,因为openssl在我使用它来签署一些数据时没有提示我输入密码。
我执行以下操作来生成我的 PKCS#12 密钥(其中$tcert 是输入密钥证书的路径)。
tcert=`dirname $tkey`/${name}.crt
key=${name}.priv.p12
echo PKCS#12 envelope without password and unencrypted RSA key
openssl pkcs12 -export -inkey $dkey -in $tcert -out d$key -name d$name -passout pass:
echo PKCS#12 envelope with password and unencrypted RSA key
openssl pkcs12 -export -inkey $dkey -in $tcert -out x$key -name $name -passout pass:mypass
echo PKCS#12 envelope with password and password protected RSA key
openssl pkcs12 -export -inkey $tkey -in $tcert -out $key -name $name -passout pass:mypass -passin pass:mypass
然后我检查每个键执行以下操作(根据需要添加 mypass)。当我去显示d 密钥时,它要求我输入 RSA 密钥的密码。如果我输入“mypass”,它会转储密钥。
openssl pkcs12 -info -in $dkey -passin pass:
由于上面是脚本,我让脚本回显这些行,以便我可以确定它使用的是正确的文件等。
我显然做错了什么,但我没有看到。
【问题讨论】:
标签: ssl encryption openssl rsa pkcs#12