gpt4 book ai didi

C# - 验证由正确的根签名的客户端证书

转载 作者:太空宇宙 更新时间:2023-11-03 14:30:54 25 4
gpt4 key购买 nike

我知道关于这个论点有很多问题,但我已经坚持了好几天,所以我来了。我有一个根证书和一个客户端证书。我需要在 C# Web API 项目中复制命令 openssl verify -CAfile ca.pem client.pem 的作用。

这是我目前所知道的(希望这是真的):

  • Verify() 方法实际验证证书是否由权威机构签署。它就像一个格式控件。哪个机构签署了证书并不重要。
  • X509 Chain 是必经之路。在额外的商店中添加您的 ca 证书,因为我不打算将证书安装到 Windows 中。然后构建传递客户端证书。让魔法发生吧!不幸的是,我在配置方面遇到了一些问题。

让我举个例子更清楚

private bool VerifyCertificate(X509Certificate2 client)
{
X509Chain chain = new X509Chain();
var stringCert = WebConfigurationManager.AppSettings["CACertificate"];
var byteCert = Encoding.ASCII.GetBytes(stringCert);
var authority = new X509Certificate2(byteCert);

chain.ChainPolicy.RevocationMode = X509RevocationMode.NoCheck;
chain.ChainPolicy.VerificationFlags = X509VerificationFlags.IgnoreWrongUsage;

chain.ChainPolicy.ExtraStore.Add(authority);

// Do the preliminary validation.
if (!chain.Build(client))
return false;

return true;
}

在此示例中,程序返回 false。构建未通过。我确定问题出在 ChainPolicy 属性上,所以我尝试了不同的配置

chain.ChainPolicy.RevocationMode = X509RevocationMode.NoCheck;
chain.ChainPolicy.RevocationFlag = X509RevocationFlag.ExcludeRoot;
chain.ChainPolicy.VerificationFlags = X509VerificationFlags.NoFlag;
chain.ChainPolicy.VerificationTime = DateTime.Now;
chain.ChainPolicy.UrlRetrievalTimeout = new TimeSpan(0, 0, 0);

但是这个不会验证任何东西,实际上使用我的 ca 证书该方法返回 true 并使用另一个 ca 证书(我没有用它来验证签署了我的客户端证书)该方法还返回 true

我搜索了 C# 的 OpenSSL 包装器,我找到了它,但不幸的是它基于旧库,并且 repo 不再被维护。此外,如果可能的话,我将仅使用 .net 框架来实现我的目标。

伙计们,快速回顾一下。我想检查只有我的ca证书确定的证书才能通过验证,其他的都必须停止。

在此先感谢您的帮助

最佳答案

ExtraStore 没有限制,它提供额外的证书来帮助完成链。它不提供信任数据。

为了确定证书是否由您想要的 CA 颁发,您需要执行以下操作:

private static readonly X509Certificate2 s_trustedRoot = ObtainTheRoot();
private static readonly byte[] s_normalizedRoot = s_trustedRoot.RawData;

private bool VerifyCertificate(X509Certificate2 candidate)
{
X509Chain chain = new X509Chain();
// set all the things you need to set to make it build

if (!chain.Build(candidate))
return false;

// Check that the root certificate was the expected one.
X509ChainElementCollection elements = chain.ChainElements;
return elements[elements.Count - 1].Certificate.RawData.SequenceEqual(s_normalizedRoot);
}

我将它的证书和规范化字节形式提升为静态,假设它们在进程启动后不会改变。如果证书可以动态更改,那么您应该相应地进行调整。

关于C# - 验证由正确的根签名的客户端证书,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52890852/

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