CaCertInstallerOfWindows.cs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. using Microsoft.Extensions.Logging;
  2. using System;
  3. using System.Security.Cryptography.X509Certificates;
  4. namespace FastGithub.HttpServer
  5. {
  6. sealed class CaCertInstallerOfWindows : ICaCertInstaller
  7. {
  8. /// <summary>
  9. /// 是否支持
  10. /// </summary>
  11. /// <returns></returns>
  12. public bool IsSupported()
  13. {
  14. return OperatingSystem.IsWindows();
  15. }
  16. /// <summary>
  17. /// 安装ca证书
  18. /// </summary>
  19. /// <param name="caCertFilePath">证书文件路径</param>
  20. /// <param name="logger"></param>
  21. public void Install(string caCertFilePath, ILogger logger)
  22. {
  23. try
  24. {
  25. using var store = new X509Store(StoreName.Root, StoreLocation.LocalMachine);
  26. store.Open(OpenFlags.ReadWrite);
  27. var caCert = new X509Certificate2(caCertFilePath);
  28. var subjectName = caCert.Subject[3..];
  29. foreach (var item in store.Certificates.Find(X509FindType.FindBySubjectName, subjectName, false))
  30. {
  31. if (item.Thumbprint != caCert.Thumbprint)
  32. {
  33. store.Remove(item);
  34. }
  35. }
  36. if (store.Certificates.Find(X509FindType.FindByThumbprint, caCert.Thumbprint, true).Count == 0)
  37. {
  38. store.Add(caCert);
  39. }
  40. store.Close();
  41. }
  42. catch (Exception)
  43. {
  44. logger.LogWarning($"请手动安装CA证书{caCertFilePath}到“将所有的证书都放入下列存储”\\“受信任的根证书颁发机构”");
  45. }
  46. }
  47. }
  48. }