我在RSACryptoServiceProvider
对象中加载了RSA私钥。我需要将其导出到.pvk文件,以用于SQL Server。
有没有一种方法可以在C#中执行此操作?我认为可以使用openssl ... https://stackoverflow.com/a/51207929/5924962
这是我可以找到的有关pvk文件格式的唯一文档:https://web.archive.org/web/20141117214716/http://www.drh-consultancy.demon.co.uk/pvk.html
答案 0 :(得分:2)
Mono项目具有PVK格式的开源实现,
请注意,
Mono.Security
NuGet软件包不是官方的。
答案 1 :(得分:1)
如果查看RSACryptoServiceProvider.ExportCspBlob的输出,您会发现它以与未加密的PVK文件的偏移量24相同的字节序列开头。因此,PVK文件只是带有标头的CSP Blob:
using (var output = new BinaryWriter(File.Create("rsa.pvk")))
{
output.Write(0xB0B5F11Eu); // PVK magic number
output.Write(0u);
output.Write(1u); // KEYTYPE_KEYX for RSA
output.Write(0u); // not encrypted
output.Write(0u); // encryption salt length
var cspBlob = rsaCSP.ExportCspBlob(true);
output.Write((uint)cspBlob.Length);
output.Write(cspBlob);
}
我已经确认OpenSSL会阅读
openssl rsa -in rsa.pvk -inform PVK
,并且将生成与the code in this answer相同的PEM私钥导出,该导出直接从RSACryptoServiceProvider生成PEM私钥。