【SSL证书系列】客户端如何验证https网站服务器发的证书是否由受信任的根证书签发机构签发

客户端验证HTTPS网站证书是否由受信任的根证书颁发机构(CA)签发,是一个多步骤的过程,涉及证书链验证、信任锚(Trust Anchor)检查、域名匹配和吊销状态验证等。以下是详细的验证流程:


1. 证书链的构成
服务器发送的证书通常是一个证书链,包含:
• 服务器证书:网站的公钥证书(由中间CA签发)。

• 中间CA证书:由根CA签发的中间证书颁发机构(Intermediate CA)的证书。

• 根CA证书:根证书颁发机构的自签名证书(通常不直接发送,而是预装在客户端系统中)。

示例:

网站证书(由 Intermediate CA 签发)  
→ Intermediate CA 证书(由 Root CA 签发)  
→ Root CA 证书(预装在客户端中,作为信任锚)

2. 验证步骤
(1) 证书链完整性验证
• 客户端(浏览器/操作系统)从服务器接收证书链,逐级验证签名:

  1. 服务器证书:用中间CA的公钥验证其签名。
  2. 中间CA证书:用根CA的公钥验证其签名。
  3. 根CA证书:客户端内置的根证书列表中是否存在该根CA?若存在,则信任链成立。

(2) 信任锚(Trust Anchor)检查
• 客户端内置的根证书列表(Trust Store)是验证的核心:

• 操作系统或浏览器预装根证书:如Windows的“受信任的根证书颁发机构”、macOS的钥匙串访问、Chrome/Firefox的内置CA列表。

• 根CA证书必须是自签名的,且客户端明确信任它(例如用户手动安装的例外情况除外)。

(3) 证书有效期验证
• 检查证书的生效日期和过期时间,确保当前时间在有效期内。

(4) 域名匹配
• 证书中的Subject Alternative Name (SAN) 或 Common Name (CN) 必须与访问的域名一致(如 example.com*.example.com)。

(5) 吊销状态检查
• 客户端需检查证书是否被CA提前吊销:

• CRL(证书吊销列表):下载CA发布的吊销列表,检查证书序列号是否在其中。

• OCSP(在线证书状态协议):直接向CA的OCSP服务器发送请求,实时查询证书状态。

• OCSP Stapling:服务器定期从CA获取OCSP响应并缓存,在TLS握手时直接发送给客户端,避免客户端直接查询。

(6) 扩展用途验证
• 检查证书的扩展字段(如 Extended Usage),确保证书类型适用于服务器身份认证(如 Server Authentication)。


3. 受信任的根证书来源
客户端信任的根证书由以下途径维护:

  1. 操作系统内置:
    • Windows:通过系统更新自动同步微软的根证书计划(Windows Root Certificate Program)。

    • macOS:钥匙串访问中预置的受信任根证书。

    • Linux:发行版提供的根证书包(如 ca-certificates 包)。

  2. 浏览器内置:
    • Chrome/Edge:使用操作系统的根证书库。

    • Firefox:独立维护自己的根证书列表(NSS数据库)。

  3. 用户手动导入:
    • 用户可手动添加根证书(例如企业内网的自签名证书),但存在安全风险。


4. 验证失败的常见原因
• 证书链不完整:服务器未发送中间CA证书,导致客户端无法构建完整信任链。

• 根证书未预装:证书由私有CA签发,但客户端未信任该CA。

• 域名不匹配:证书中的域名与访问的域名不一致。

• 证书过期:证书已超过有效期。

• 吊销状态异常:证书已被CA吊销,且OCSP/CRL检查失败。


5. 示例:Let’s Encrypt 的证书验证

  1. Let’s Encrypt 使用中间CA(如 ISRG Root X1)签发服务器证书。
  2. 客户端检查中间CA的签名是否由根CA(如 DST Root CA X3ISRG Root X1)签发。
  3. 根CA是否在客户端的信任列表中?如果是,则验证成功。

6. 总结
客户端验证的核心逻辑是:
“服务器证书的签发路径必须最终链接到客户端信任的根CA,且所有中间环节均合法有效。”
如果任一环节失败(如证书链断裂、域名不匹配、吊销状态异常),客户端会提示安全警告(如“您的连接不是私密连接”)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/81196.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS即时通信的技术要点

iOS即时通信开发的关键技术要点总结: 一、通讯协议选择 Socket通信 基础实现:使用原生BSD Socket或CFNetwork框架(复杂),推荐第三方库如CocoaAsyncSocket(封装GCDAsyncSocket),简化T…

智能AI构建工地安全网:跌倒、抽搐、区域入侵多场景覆盖

智能AI在工地安全中的应用:从监测到救援的全流程实践 一、背景:高温作业下的工地安全挑战 随着夏季高温持续,工地户外作业环境面临严峻考验。工人因高温疲劳、脱水或突发疾病引发的行为异常(如晕厥、抽搐、跌倒)频发…

Doris

Apache Doris(原名:Palo)是一个高性能、实时的MPP分析型数据库,非常适合海量数据的即席查询、报表分析、指标统计等 OLAP 场景。Doris 的设计目标是:极致查询性能、简单易用、支持高并发分析和明细查询。 一、Doris 核…

# 2-STM32F103-复位和时钟控制RCC

STM32-复位和时钟控制RCC 2-STM32-复位和时钟控制RCC摘要说明本文参考资料如下: 一、STM32最小系统回顾STM32F103C8T6核心板原理图 二、复位三、时钟3.1 时钟树3.2 STM32启动过程3.2 SystemInit()函数3.2.1 SystemInit()第1句:3.2.2 SystemInit()第2句&a…

rk3576 gstreamer opencv

安装gstreamer rk3588使用gstreamer推流_rk3588 gstreamer-CSDN博客 rk3588使用gstreamer推流_rk3588 gstreamer-CSDN博客 Installing on Linux sudo apt-get install libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev libgstreamer-plugins-bad1.0-dev gstreamer1.0-pl…

Quic如何实现udp可靠传输

QUIC(Quick UDP Internet Connections)是由 Google 设计并被 IETF 标准化的传输层协议,它基于 UDP 实现,但提供了类似 TCP 的可靠性和更高级的功能(如多路复用、0-RTT 握手、TLS 加密等)。 尽管 UDP 是不可…

uniapp-商城-59-后台 新增商品(属性的选中,进行过滤展示,filter,some,every和map)

前面讲了属性的添加,添加完成后,数据库中已经存在数据了,这时再继续商品的添加时,就可以进行属性的选择了。 在商品添加过程中,属性选择是一个关键步骤。首先,界面需要展示嵌套的属性数据,用户通…

负载均衡 ELB 在 zkmall开源商城高流量场景下的算法优化

在电商大促、直播带货等高频交易场景下,流量突发增长对系统稳定性提出严峻挑战。ZKmll 开源商城通过对负载均衡 ELB(Elastic Load Balancer)算法的深度优化,结合业务场景特性设计动态加权轮询 地域感知 热点分流的混合策略&…

Linux干货(三)

前言 从B站黑马程序员Linux课程摘选的学习干货,新手友好!若有侵权,会第一时间处理。 目录 前言 1.which find命令 1.which命令 2.find命令 2.grep wc 管道符 1.grep命令 2.wc命令 3.管道符 3.echo tail 重定向符 1.echo命令 2.反…

Sigmoid与Softmax:从二分类到多分类的深度解析

Sigmoid与Softmax:从二分类到多分类的深度解析 联系 函数性质:二者都是非线性函数 ,也都是指数归一化函数,可将输入值映射为0到1之间的实数 ,都能把输出转化成概率分布的形式,在神经网络中常作为激活函数使用。Softmax是Sigmoid的推广:从功能角度看,Softmax函数可视为…

文件系统交互实现

关于之前的搭建看QT控件文件系统的实现-CSDN博客,接下来是对本程序的功能完善,我想着是这样设计的,打开一个目录以后,鼠标选中一个项可以是目录,也可以是文件,右键可以出现一个菜单选择操作,比如…

[ctfshow web入门] web75

信息收集 启用了open_basedir,所以之前的方法又不能用了 解题 cforeach(new DirectoryIterator("glob:///*") as $a){echo($a->__toString(). ); } ob_flush();cif ( $a opendir("glob:///*") ) {while ( ($file readdir($a)) ! false …

Vulfocus靶场-文件上传-3

WSO2 文件上传 (CVE-2022-29464) WSO2是一家成立于 2005 年的开源技术提供商。它提供了一个企业平台,用于在本地和整个 Internet 上 集成应用程序编程接口(API)、应用程序和 Web 服务。 某些 WSO2 产品允许无限制的文件上传和远程代码执行。…

基于MCP的桥梁设计规范智能解析与校审系统构建实践

引言 今天本文准备盘一个大活,聊一聊偏特定行业一点的AI技术深入应用思考及实践。 一、传统设计行业项目背景与行业痛点 在桥梁设计领域,标准规范是设计的基础,直接关系到桥梁结构的安全性、耐久性和经济性。然而,传统的规范应…

远程连接电脑的方法?异地远程桌面连接和三方软件实现

远程连接电脑,是指通过网络技术,在一台设备上操控另一台设备的电脑桌面,实现跨地域的操作和管理。在日常工作、技术支持、远程办公等场景中,远程连接电脑都发挥着重要作用。实现远程连接电脑主要有系统自带工具和第三方软件两种方…

win11 安装 wsl ubuntu 18.04后换源失败!

记录几个问题是如何解决的。 一 下载wsl后,有报错: Installing, this may take a few minutes... WslRegisterDistribution failed with error: 0x8007019e Error: 0x8007019e ??????? Linux ? Windows ???? Press any key to continue... …

PY32系列单片机离线烧录器,可配置选项字节和上机台批量烧录

PY32离线烧录器采用 MINI-USB 接口,提供稳定的物理连接。设备与电脑采用串口方式通讯,波特率固定为 1M。需配合我们的上位机使用。PY32离线烧录器现支持芯片型号在PY32F002A/002B/002/003/030/071/072/040/403/303各封装和XL32F001/003。烧录器仅提供 3.…

深入理解 this 指向与作用域解析

引言 JavaScript 中的 this 关键字的灵活性既是强大特性也是常见困惑源。理解 this 的行为对于编写可维护的代码至关重要,但其动态特性也会让我们感到困惑。 与大多数编程语言不同,JavaScript 的 this 不指向函数本身,也不指向函数的词法作…

# IntelliJ IDEA企业版开发入门:包、类与项目结构详解

--- ## 一、项目结构与包的概念 ### 1. 标准项目目录解析 在IntelliJ IDEA中,一个Java项目通常包含以下核心目录: - **src**:源代码根目录。 - **main**:主代码目录,存放业务逻辑代码。 - **java**:Java…

NGINX 开源与社区动态:从基石到浪潮,持续演进的生态力量

NGINX 之所以能够成为全球应用最为广泛的 Web 服务器和反向代理软件之一,其成功的核心驱动力无疑是开源。开放的源代码、活跃的社区参与以及透明的开发过程,共同铸就了 NGINX 的辉煌。然而,正如所有大型开源项目一样,NGINX 的开源之路也并非一帆风顺,其社区动态也时常涌现…