gpt4 book ai didi

c# - 无效的基本约束 : A certificate's basic constraint extension has not been observed

转载 作者:行者123 更新时间:2023-12-02 17:45:26 24 4
gpt4 key购买 nike

我收到错误 “InvalidBasicConstraints:未观察到证书的基本约束扩展。” 此证书是随 OpenSSL 颁发的,将用作 WCF 服务的服务器端测试证书(在验证证书时会出现相同的错误)。我可以用这段代码复制错误。

X509Certificate2 cert = new X509Certificate2(@"c:\test.cer");

X509Chain chain = X509Chain.Create();
X509ChainPolicy policy = new X509ChainPolicy();
policy.RevocationMode = X509RevocationMode.NoCheck;
chain.ChainPolicy = policy;
bool valid = chain.Build(cert);

Console.WriteLine(string.Join(" -- ", chain.ChainStatus.Select(o => o.Status + ": " + o.StatusInformation)));
Console.WriteLine(valid ? "VALID" : "NOT VALID");

查看证书我可以看到这些基本约束,

Subject Type=End Entity
Path Length Constraint=None

这个错误是什么意思,我该如何解决?

我找到的关于基本约束最相关的文章是这篇文章,http://unitstep.net/blog/2009/03/16/using-the-basic-constraints-extension-in-x509-v3-certificates-for-intermediate-cas/然而,它只讨论禁止子证书签署/创建更多子证书,在我的情况下我不想这样做。

此外,任何解释上述基本约束含义的引用资料都会有所帮助。

最佳答案

http://forums.juniper.net/t5/SSL-VPN/quot-Failed-to-authenticate-client-certificate-quot-after/td-p/89232/page/4

看完上面的帖子后,我看到有两种不同的主题类型,

Basic Constraints: Subject Type=CA, Length Constraint=None
Basic Constraints: Subject Type=End Entity, Path Length Constraint=None

我使用的服务器端证书实际上是层次结构中的第三个链接。

A -> B -> C....A 签发 B,然后签发 C。

证书 B 在基本约束中也有 Subject Type=End Entity。我找不到任何说明不同类型的基本约束或其含义的文档,但基于上述两种类型的差异,我会说 End Entity 意味着它不能颁发证书。它是链的末端,与 Subject Type=CA 相对。

当 .NET 验证链时,它发现 B 没有来自其父证书的权限来颁发证书并抛出错误,A certificate's basic constraint extension has not been observed

编辑:使用自签名证书颁发的新证书进一步测试验证了上述理论。

关于c# - 无效的基本约束 : A certificate's basic constraint extension has not been observed,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15375937/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com