7

我正在尝试X509Certificate2从 XML 文件在 C# 中创建一个对象。XML 文件是SAML我们从供应商处收到的元数据文件。

我正在尝试从这些 XML 元素中提取公钥:

<X509Data>
    <X509Certificate>
      MIIB7DCCAVmgAwIBAgIQPjHcBTL63bBLuJZ88RcrCjAJBgUrDgMCHQUAMBExDzANBgNVBAMT
      BnJvbWVvazAgFw0xMDAzMTUwMjI1MjZaGA8yMTEwMDIxOTAyMjUyNlowETEPMA0GA1UEAxMG
      cm9tZW9rMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDAu/sBh13A27rR7gJpZsI6zCee
      TXNohQWlq2z6Zg8Oxzsy5JoVV 
    </X509Certificate>
</X509Data> 

C# 中有没有办法从 XML 元素中提取 .cer 文件或公钥?

4

2 回答 2

9

兰德尔的回答是正确的。但在 SAML Token 中,我相信证书将始终是 Base64 编码的。因此,对于后代来说,对我有用的解决方案是:

var document = new XmlDocument();
document.LoadXml(txtXml.Text);
var certificateStr = document.SelectSingleNode("X509Data/X509Certificate").InnerText;
byte[] data = Convert.FromBase64String(certificateStr);
var x509 = new X509Certificate2(data);
Console.WriteLine("Public Key Format: {0}", x509.PublicKey.EncodedKeyValue.Format(true));
于 2014-04-08T17:33:07.290 回答
7

在不知道 X509Certificate 是如何编码的情况下,这是一个很难回答的问题,但是假设您有编码的东西,您可以执行以下操作:

  var document = new XmlDocument();
  document.LoadXml(txtXml.Text);
  var cert = document.SelectSingleNode("X509Data/X509Certificate").InnerText;
  /*...Decode text in cert here (may need to use Encoding, Base64, UrlEncode, etc) ending with 'data' being a byte array...*/ 
  var x509 = new X509Certificate2(data);

然后您应该能够使用标准文件 I/O 逻辑将文件写入磁盘。

于 2013-04-11T20:47:52.527 回答