https 的Secure Sockets Layer (SSL)/Transport Layer Security (TLS)证书过期

https证书过期 ,中文浏览器edge,google chrome 提交显示报错为“连接已重置” ,英文firfox浏览器 报错为“Secure Connection Failed

 

 

 

 

一、问题分析

 

  • 证书过期:当网站使用的 HTTPS 证书过期时,浏览器会认为该网站的安全性无法得到保证,因此会阻止用户访问该网站。不同浏览器可能会显示不同的错误信息,但本质上都是因为证书的有效性问题。
  • 连接已重置(Edge、Google Chrome):这表示浏览器尝试建立安全连接,但在验证证书时发现证书过期,为了确保用户的安全,浏览器中断了连接。
  • Secure Connection Failed(Firefox):此错误表明 Firefox 也检测到了证书问题,无法建立安全的连接。

 

二、解决思路

 

  1. 更新证书:这是最根本的解决方法,需要向证书颁发机构重新申请新的证书,并将其部署到服务器上。
  2. 检查证书链:确保证书链完整且有效,有时可能是中间证书或根证书出现问题导致的连接问题。
  3. 临时解决方法:在测试或开发环境中,可以暂时允许不安全的连接,但这绝对不建议用于生产环境,因为会带来严重的安全风险。

 

三、代码示例(用于检查证书过期)
以下是一段 C# 代码,可用于检查服务器证书是否过期:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
string url = "https://www.iloveyou.com";
ServicePointManager.ServerCertificateValidationCallback += (sende, certificate, chain, sslPolicyErrors) =>
{
    if (sslPolicyErrors == SslPolicyErrors.None)
    {
        X509Certificate2 cert = (X509Certificate2)certificate;
        if (cert.NotAfter < DateTime.Now)
        {
            Response.Write("The certificate has expired.");
        }
        else
        {
            Response.Write("The certificate is valid.");
        }
        return true;
    }
    else
    {
        Response.Write("SSL Policy Errors: " + sslPolicyErrors);
        return false;
    }
};
 
try
{
    using (WebClient client = new WebClient())
    {
        string response = client.DownloadString(url);
        Response.Write(response);
    }
}
catch (WebException ex)
{
    if (ex.Status == WebExceptionStatus.TrustFailure)
    {
        // 处理SSL/TLS信任失败的情况
        Console.WriteLine("SSL/TLS证书验证失败。");
        // 这里可以添加额外的逻辑,例如记录日志、通知用户等
    }
    else
    {
        // 处理其他类型的WebException
        Console.WriteLine("WebException: " + ex.Status);
    }
 
 
    
}
catch (Exception ex)
{
    Response.Write("Error: " + ex.Message);
}

  

四、更新证书的一般步骤
生成证书签名请求(CSR):

1
2
openssl req -new -newkey rsa:2048 -nodes -keyout yourdomain.key -out yourdomain.csr
  

  


在服务器上使用 openssl 或其他工具生成 CSR。
向证书颁发机构申请证书:
将 CSR 文件提交给证书颁发机构(如 Let's Encrypt、Comodo、DigiCert 等)。
通常需要提供一些组织和域名信息,并完成验证步骤,例如 DNS 验证或文件验证。
安装新证书:
收到证书颁发机构颁发的证书后,将证书文件和可能的中间证书文件部署到服务器上。
对于不同的服务器软件(如 Apache、Nginx、IIS),安装步骤有所不同
Apache:

1
2
3
SSLCertificateFile /path/to/yourdomain.crt
SSLCertificateKeyFile /path/to/yourdomain.key
SSLCertificateChainFile /path/to/intermediate.crt

  


Nginx:

1
2
3
ssl_certificate /path/to/yourdomain.crt;
ssl_certificate_key /path/to/yourdomain.key;
ssl_trusted_certificate /path/to/intermediate.crt;

  


IIS:


通过 IIS 管理器导入证书,并将其绑定到相应的网站上。
五、检查证书链
可使用 openssl 工具检查证书链:

1
openssl s_client -showcerts -connect example.com:443

  

六 临时解决方法(不推荐用于生产环境)

 无效或是不稳定,有时不是不可访问。

    • 在某些开发或测试环境中,可在浏览器中添加异常以允许访问:
      • Edge/Chrome:在错误页面点击 “高级”,然后选择 “继续前往 [网站域名](不安全)”。
      • Firefox:在错误页面点击 “高级”,然后选择 “添加例外”,确认安全例外。

 

 

 

 

 

 

 

 

七、注意事项
对于生产环境,务必尽快更新证书,以保证网站的安全性和正常访问。
对于代码检查证书,需要确保代码在运行时的网络环境允许连接到目标服务器。
在更新证书时,确保私钥的安全,避免泄露。
通过上述步骤和代码,你可以检查证书是否过期,更新证书,并确保服务器的 HTTPS 连接安全可靠。请根据实际情况选择合适的解决方法,避免因证书过期而导致的安全和访问问题。

 

预防措施
定期监控证书有效期:使用自动化工具定期监控SSL/TLS证书的有效期,并在证书即将过期时发送提醒。
使用受信任的证书颁发机构:选择受信任的证书颁发机构,并确保购买的证书符合您的安全需求。
保持服务器和浏览器更新:定期更新服务器和浏览器软件,以确保它们支持最新的安全协议和最佳实践。
通过遵循这些解决方法和预防措施,您可以有效地解决HTTPS证书过期导致的连接问题,并保护您的网站和用户免受潜在的安全威胁。

Full Stack Python Security: Cryptography, TLS, and attack resistance

 Cross-platform cryptography in .NET - .NET | Microsoft Learn

https://learn.microsoft.com/en-us/dotnet/standard/security/cross-platform-cryptography

另一说:

  1. 更新服务器证书:
    • 服务器管理员需要联系证书颁发机构(CA)续签或重新购买证书,并在服务器上安装新的有效证书。
  2. 检查服务器配置:
    • 确保服务器正确配置了SSL/TLS协议和证书链。服务器应该只使用受支持的协议版本,并且证书链应该完整且正确。
  3. 清除浏览器缓存:
    • 尝试清除浏览器的SSL状态缓存和常规缓存。这可以通过浏览器的设置菜单完成。
  4. 检查网络连接:
    • 确保网络连接是安全的,没有中间人攻击或其他网络问题。
  5. 使用浏览器的高级设置:
    • 在某些情况下,可以通过浏览器的高级设置或命令行参数来绕过证书验证(例如,在开发环境中)。然而,这通常不推荐在生产环境中使用,因为它会降低安全性。
  6. 检查防火墙和安全软件:
    • 确保防火墙和安全软件没有阻止SSL/TLS连接。
  7. 联系网站管理员:
    • 如果问题仍然存在,请联系网站的管理员或技术支持团队,以获取有关如何解决该问题的帮助
posted @   ®Geovin Du Dream Park™  阅读(28)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Blazor Hybrid适配到HarmonyOS系统
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· 分享4款.NET开源、免费、实用的商城系统
· 解决跨域问题的这6种方案,真香!
· 一套基于 Material Design 规范实现的 Blazor 和 Razor 通用组件库
历史上的今天:
2023-01-21 javascript: node.js
2015-01-21 sql: TRIGGER
2014-01-21 SQL:Example Uses of the SUBSTRING String Function
2010-01-21 What Are Web Parts?
2010-01-21 css 汉字注音,日本语片假名
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示