首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >解析没有私钥的PKCS7SSL证书链(.p7b)?

解析没有私钥的PKCS7SSL证书链(.p7b)?
EN

Stack Overflow用户
提问于 2011-08-19 02:19:50
回答 1查看 6.5K关注 0票数 4

我有一个PKCS7,签名的.p7b文件,其中包含一个SSL证书和中间和根CA证书,它是用来签名的。我需要使用C#解析.p7b文件,提取SSL证书,并从中提取一些值(过期日期、DN等)。

我尝试将其作为X509证书读取,如下所示:

代码语言:javascript
复制
//certContent is a byte array with the p7b file contents
X509Certificate2 cert = new X509Certificate2(certContent);

这可以很好地用于常规.cer证书,但在与.p7b证书一起使用时会抛出CryptographicException。这是因为.p7b包含整个证书链。

我还尝试将其解析为SignedCms对象,然后遍历证书链并取出我的SSL证书:

代码语言:javascript
复制
SignedCms certContainer = new SignedCms();
certContainer.Decode(certContent);
foreach(X509Certificate2 cert in certConatiner.Certificates)
{
     ...
}

然而,这在Decode上抛出了一个异常,即ASN1 bad tag value met。经过一些搜索,我认为这是因为我没有用于创建证书和/或签署证书的私钥。

有人知道如何使用C#解析这个.p7b证书链吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-08-19 02:29:35

好吧,我是个笨蛋。我打开了.p7b文件,发现里面只有base64。我取出base64,将其解码,然后将其解析为已签名的内容管理系统,一切正常。

代码语言:javascript
复制
String content = Encoding.UTF8.GetString(certContent);
String base64Content = content.Replace("-----BEGIN CERTIFICATE-----", "").Replace("-----END CERTIFICATE-----", "").Replace("\r", "").Replace("\n", "");
byte[] decodedContent = Convert.FromBase64String(base64Content);
SignedCms certContainer = new SignedCms();
certContainer.Decode(decodedContent);
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7112148

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档