繁体   English   中英

从字节[] / pem字符串获取公共密钥-BouncyCastle C#

[英]Get public key from byte [] / pem string - BouncyCastle C#

我正在编写与SmartCard通信的程序。 智能卡是公钥的来源。 我将公共密钥作为字节[]并将其转换为String 我想使用密钥创建证书签名请求

如何将byte [] /字符串(我的公共密钥)转换为任何C#密钥参数(例如RsaKeyParameters或AsymmetricKeyParameter)?

我找到了很好的解释我的问题。 这里读所有的answears。 我必须根据X.509 SubjectPublicKeyInfo / OpenSSL PEM公共密钥格式将字节(公共密钥)放入适当的ASN1结构中 现在,我可以创建AsymmetricKeyParameter了。

    public static byte[] ConvertFromStringToHex(string inputHex)
    {
        inputHex = inputHex.Replace("-", "");

        byte[] resultantArray = new byte[inputHex.Length / 2];
        for (int i = 0; i < resultantArray.Length; i++)
        {
            resultantArray[i] = Convert.ToByte(inputHex.Substring(i * 2, 2), 16);
        }
        return resultantArray;
    }

    static void Main(string[] args)
    {
        var certObject = new Cryptography.CertificateManager();
        //AsymmetricKeyParameter privatekey = certObject.ReadCaPrivateKeyFromFile();
        string ASN1 = "";
        string prefix = "30 81 9F 30 0D 06 09 2A 86 48 86 F7 0D 01 01 01 05 00 03 81 8D 00 30 81 89 02 81 81 00 ";

        string suffix = " 02 03 01 00 01";
        string key = "96 33 A5 49 EB 9E 11 7F 73 3E 36 8C ED 73 D9 24 DC 8B DF A2 75 D3 E1 EA E9 44 BD 63 7A C1 D1 A6 E5 2E E5 64 55 AB FA C7 35 99 BF D1 CE 53 F3 E6 58 F8 DF 8A 6D CC 4C C9 98 5E 65 EA A2 5F 8C A3 43 6F 6C 08 D9 32 F7 29 4E 32 FE 4C 81 15 96 B7 AE B0 AE CE C2 07 C3 36 98 0B 90 4D EE 25 29 9A 56 4A 91 FE B6 C3 C0 BD 33 D4 BD 5F 33 0C 1F FF 93 D3 F3 EF 00 19 30 8F C0 7C B8 1C 0A AA A7 49";

        ASN1 = prefix + key + suffix;
        ASN1 = ASN1.Replace(" ", "");

        byte[] publicKeyByte = ConvertFromStringToHex(ASN1);
        string publicKeyBase64 = Convert.ToBase64String(publicKeyByte);

        AsymmetricKeyParameter publicKey = PublicKeyFactory.CreateKey(publicKeyByte);

这是从pem字符串获取X509Certificate的简单方法:

pemString = pemString.Replace("-----BEGIN CERTIFICATE-----", "").Replace("-----END CERTIFICATE-----", "");
byte[] buffer = Convert.FromBase64String(pemString);
X509CertificateParser parser = new X509CertificateParser();
_certificate = parser.ReadCertificate(buffer);

当我们拥有X509Certificate对象时,我们可以获得公共密钥:

AsymmetricKeyParameter publicKey = certificate.GetPublicKey();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM