Es gibt einen Weg, die CertEnroll-Bibliothek, die mit Windows geliefert wird (obwohl ich nicht sagen kann, wie weit zurück gibt es gewesen ist) können Sie Zertifikatsanforderungen laden und sie analysiert.
Zuerst müssen Sie einen Verweis auf die COM-Bibliothek CERTENROLLLib
in Ihr Projekt importieren. Dadurch wird ein CERTENROLLLib
Namensraum erstellt, den Sie dann verwenden können.
Dann machen Sie so etwas;
string csr = "-----BEGIN CERTIFICATE REQUEST-----\r\n" +
"MIIBnTCCAQYCAQAwXTELMAkGA1UEBhMCU0cxETAPBgNVBAoTCE0yQ3J5cHRvMRIw\r\n" +
"EAYDVQQDEwlsb2NhbGhvc3QxJzAlBgkqhkiG9w0BCQEWGGFkbWluQHNlcnZlci5l\r\n" +
"eGFtcGxlLmRvbTCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAr1nYY1Qrll1r\r\n" +
"uB/FqlCRrr5nvupdIN+3wF7q915tvEQoc74bnu6b8IbbGRMhzdzmvQ4SzFfVEAuM\r\n" +
"MuTHeybPq5th7YDrTNizKKxOBnqE2KYuX9X22A1Kh49soJJFg6kPb9MUgiZBiMlv\r\n" +
"tb7K3CHfgw5WagWnLl8Lb+ccvKZZl+8CAwEAAaAAMA0GCSqGSIb3DQEBBAUAA4GB\r\n" +
"AHpoRp5YS55CZpy+wdigQEwjL/wSluvo+WjtpvP0YoBMJu4VMKeZi405R7o8oEwi\r\n" +
"PdlrrliKNknFmHKIaCKTLRcU59ScA6ADEIWUzqmUzP5Cs6jrSRo3NKfg1bd09D1K\r\n" +
"9rsQkRc9Urv9mRBIsredGnYECNeRaK5R1yzpOowninXC\r" +
"-----END CERTIFICATE REQUEST-----";
CX509CertificateRequestPkcs10 request = new CX509CertificateRequestPkcs10();
request.InitializeDecode(csr, EncodingType.XCN_CRYPT_STRING_BASE64_ANY);
request.CheckSignature();
Console.WriteLine(((CX500DistinguishedName)request.Subject).Name);
Console.WriteLine(request.PublicKey.Length);
Console.WriteLine(request.HashAlgorithm.FriendlyName);
können Sie sehen, die nur Spaß Teil der Subjektname aus wird immer, wie Sie es zu einem CX500DistinguishedName
Instanz zuerst werfen müssen.
Ich habe keine Erfahrung damit, aber überprüfen Sie die Bouncy Castle API. Die Java-Implementierung liest CSRs, und die C# -Implementierung soll "die meisten" Java-Funktionen bereitstellen. http://www.bouncycastle.org/csharp/ –