CaCertInstallerOfWindows.cs 1.9 KB

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