HTTPS如何保障安全?詳解證書體系與加密通信流程

HTTP協議本身是明文傳輸的,安全性較低,因此現代互聯網普遍采用 HTTPS(HTTP over TLS/SSL) 來實現加密通信。HTTPS的核心是 TLS/SSL證書體系加密通信流程

一、HTTPS 證書體系

HTTPS依賴 公鑰基礎設施(PKI, Public Key Infrastructure)數字證書 來驗證服務器身份并建立安全連接。

1. 數字證書的作用

  • 身份認證:證明服務器是合法的(如 example.com 的擁有者)。
  • 密鑰交換:用于協商加密通信的密鑰。
  • 數據完整性:防止數據被篡改。

2. 證書的組成

字段

說明

域名(CN/SAN)

證書綁定的域名(如 example.com),支持多域名(SAN擴展)。

公鑰

服務器的公鑰,用于加密數據或驗證簽名。

頒發者(CA)

簽發證書的證書頒發機構(如 Let's Encrypt、DigiCert)。

有效期

證書的生效和過期時間(通常1年~2年)。

簽名算法

用于驗證證書的算法(如 SHA-256 + RSA)。

數字簽名

CA對證書的哈希值用私鑰加密后的結果,用于驗證證書真實性。

3. 證書類型

類型

特點

DV(域名驗證)

僅驗證域名所有權,適合個人網站(如 Let's Encrypt)。

OV(組織驗證)

驗證企業身份,適合企業網站(如銀行、政府機構)。

EV(擴展驗證)

嚴格驗證企業身份,瀏覽器地址欄顯示公司名稱(已逐漸被棄用)。

4. 證書鏈(Chain of Trust)

HTTPS證書采用層級信任模型:

  1. 根證書(Root CA)
  • 由受信任的根證書頒發機構(如 DigiCert、GlobalSign)管理。
  • 預裝在操作系統/瀏覽器中(如 Windows Trusted Root Store)。
  1. 中間證書(Intermediate CA)
  • 由根CA簽發,用于實際頒發終端證書(避免根CA私鑰直接暴露)。
  1. 終端證書(End-Entity Certificate)
  • 最終提供給網站的證書(如 example.com)。

驗證流程
瀏覽器檢查證書簽名鏈是否可追溯到受信任的根CA。

二、HTTPS 加密通信流程(TLS握手)

HTTPS 的加密通信分為兩大階段:握手階段?和數據傳輸階段

1. 客戶端發起請求(ClientHello)

  • 瀏覽器訪問 https://example.com,發送:
    • 支持的TLS版本(如 TLS 1.3)。
    • 支持的加密套件(如 AES256-GCM-SHA384)。
    • 隨機數(Client Random)。

2. 服務器響應(ServerHello)

  • 服務器返回:
    • 選擇的TLS版本和加密套件。
    • 隨機數(Server Random)。
    • 數字證書(包含公鑰)。
    • (可選)要求客戶端證書(雙向認證,罕見)。

3. 客戶端驗證證書

  • 瀏覽器檢查:
  1. 證書是否由受信任的CA簽發。
  2. 證書是否在有效期內。
  3. 證書綁定的域名是否匹配當前訪問的域名。
  4. 證書是否被吊銷(通過OCSP或CRL)。

4. 密鑰交換(Key Exchange)

  • TLS 1.2及之前
    客戶端生成 Pre-Master Secret,用服務器公鑰加密后發送。
  • TLS 1.3(簡化)
    直接通過 DH(Diffie-Hellman) 算法協商密鑰,無需加密傳輸。

5. 生成會話密鑰

  • 客戶端和服務器使用:
    • Client Random + Server Random + Pre-Master Secret
      • → 生成 Master Secret
      • → 派生 會話密鑰(Session Key)(用于對稱加密通信)。

6. 加密通信開始

  • 客戶端發送數據:用會話密鑰加密→服務器用會話密鑰解密。
  • 服務器返回數據:用會話密鑰加密→客戶端用會話密鑰解密。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/90257.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/90257.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/90257.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

數據的評估與清洗篇---清洗數據

處理前的準備 檢查索引與列名 在處理內容之前,需要先看看索引或列名是否有意義,若索引和列名都是亂七八糟的,應該對他們進行重命名或者重新排序,以便我們理解數據。 清洗數據 清洗數據原則 針對數據內容,一般先解決結構性問題,再處理內容性問題。整潔數據的特點是: …

Ubuntu apt和apt-get的區別

好的,這是一個非常經典且重要的問題。apt install 和 apt-get install 的區別是很多 Ubuntu/Debian 新手都會遇到的困惑。 簡單來說,它們的功能非常相似,但設計目標和用戶體驗不同。 一句話總結 apt 是 apt-get 的一個更新、更友好、更現代化…

多端適配災難現場:可視化界面在PC/平板/大屏端的響應式布局實戰

摘要精心設計的可視化大屏,在平板上顯示時圖表擠成一團,在PC端操作按鈕小到難以點擊,某企業的可視化項目曾因多端適配失敗淪為“災難現場”,不僅用戶差評如潮,還被競爭對手嘲諷技術落后。多端適配真的只能靠“反復試錯…

Vulnhub Web-Machine-N7靶機攻略(附VB安裝教程)

1.VB安裝 安裝地址:https://download.virtualbox.org/virtualbox/7.1.12/VirtualBox-7.1.12-169651-Win.exe 下載好后直接打開即可開始安裝。安裝前先打開任務管理器(搜索框直接搜索即可)查看性能里面的虛擬化是否打開。 開始安裝。 這里顯…

vite搭建react-ts項目,@別名配置

vite搭建react-ts項目,別名配置一、配置別名二、輸入/能索引文件三、解決找不到模塊“/pages/home”或其相應的類型聲明一、配置別名 vite.config.ts文件 import { defineConfig, loadEnv, type ConfigEnv, type UserConfig } from "vite"; import reac…

AWS OpenSearch 搜索排序常見用法

背景介紹 AWS OpenSearch是AWS的一個檢索分析服務&#xff0c;是基于開源的Elasticsearch 7.x分支fork出來的獨立的一個代碼倉庫&#xff0c;做了獨立的維護&#xff0c;加入了一些自己的優化&#xff0c;本文在這里主要介紹是常見的基礎用法 引入相關依賴<dependency>&l…

深度分析Java內存結構

Java內存結構是JVM的核心機制&#xff0c;直接關系到程序性能、并發能力和穩定性。下面從規范、實現到實踐進行深度分析&#xff1a;一、JVM規范定義的內存區域 1. 程序計數器&#xff08;Program Counter Register&#xff09; 作用&#xff1a;存儲當前線程執行的字節碼指令地…

vs2019 創建MFC ActiveX的詳細步驟

第一步 創建1個MFC ActiveX控件工程 添加方法 輸入方法名稱選擇返回類型點擊 添加參數&#xff0c;最后點擊確認&#xff0c;如下圖 添加的Add方法 注意&#xff0c;如需要添加1個指針類型的參數&#xff0c;需要手動輸入* 最后編譯&#xff0c;如編譯出現下圖錯誤&#xf…

pyarmor加密源代碼

使用低版本python 避免出現加密限制&#xff0c;無法加密情況 環境&#xff1a;python3.9.9 安裝 pyinsatller 及 pyarmor pip install pyinsatller pyarmor添加 其它pyinstaller 打包參數 一定在下邊正式打包命令運行前執行 具體參考 https://pyarmor.readthedocs.io/zh/stabl…

MACOS安裝配置Gradle

一、概述 gradle的運行高度依賴jvm版本&#xff0c;所以在安裝之前一定要先安裝jdk&#xff0c;同時gradle版本必須與jdk版本對應&#xff0c;不然在項目編譯的時候會報版本不兼容導致編譯不成功的問題。 官方說明地址 以下是官方列出關系對應版本的關系列表&#xff1a; 本文…

1.1.2 建筑構造要求

1、建筑構造的影響因素1&#xff09;荷載因素&#xff08;受力&#xff09;&#xff1a;結構自重、活荷載、風荷載、雪荷載、地震作用2&#xff09;環境因素&#xff1a;自然因素&#xff08;風吹、日曬、雨淋、積雪、冰凍、地下水、地震等&#xff09;、人為因素&#xff08;火…

gig-gitignore工具實戰開發(一):項目愿景與藍圖規劃

文章目錄gig-gitignore工具實戰開發&#xff08;一&#xff09;&#xff1a;項目愿景與藍圖規劃 &#x1f680;&#x1f631; 一、痛點&#xff1a;被忽視的.gitignore&#x1f3af; 二、愿景&#xff1a;.gitignore的全生命周期管理&#x1f6e0;? 三、核心功能規劃&#x1f…

C# 基于halcon的視覺工作流-章22-直線查找

C# 基于halcon的視覺工作流-章22-直線查找 本章目標&#xff1a; 一、創建直線卡尺工具&#xff1b; 二、測量及擬合直線&#xff1b; 三、匹配批量查找&#xff1b;尋找整圖中所有直線&#xff0c;可用霍夫直線查找等算法&#xff0c;而尋找圖片中指定區域的直線&#xff0c;除…

統計與大數據分析與數學金融方向課程差異有哪些?如何提升職場競爭力?

準大一新生在選擇專業時&#xff0c;常常會在 “統計與大數據分析” 和 “數學金融” 之間猶豫不決。這兩個專業看似都與數字、模型打交道&#xff0c;課程設置存在一定交叉&#xff0c;但核心方向又各有側重。深入了解它們的異同&#xff0c;能為專業選擇和學習規劃提供更清晰…

游戲開發Unity/ ShaderLab學習路徑

掌握 ShaderLab 需要循序漸進地學習&#xff0c;結合理論、實踐和工具。以下是一個推薦的學習路徑&#xff0c;幫助你從零基礎逐步進階&#xff1a; 階段一&#xff1a;基礎準備 (理解核心概念與環境)必備知識&#xff1a; 編程基礎&#xff1a; 至少熟悉一種編程語言&#xff…

算法----二叉搜索樹(BST)

系列文章目錄 算法----滑動窗口 算法----二叉樹 文章目錄系列文章目錄二叉搜索樹心法&#xff08;特性篇&#xff09;二叉搜索樹心法&#xff08;基操篇&#xff09;1、判斷 BST 的合法性2、在 BST 中搜索元素3、在 BST 中插入一個數4、在 BST 中刪除一個數二叉搜索樹心法&…

GitHub Actions打包容器,推送 AWS ECR 并使 EKS 自動拉取以完成發版部署

以下是關于 EKS 直接拉取 ECR 鏡像的解答&#xff0c;以及如何通過 GitHub Actions 將項目打包為容器、推送至 AWS ECR 并使 EKS 自動拉取以完成發版部署的詳細步驟。當前時間為 2025 年 7 月 23 日下午 12:27 HKT&#xff0c;基于最新技術實踐提供方案。1. EKS 直接拉取 ECR 鏡…

洛谷刷題7.24

P1087 [NOIP 2004 普及組] FBI 樹 - 洛谷 簡單的二叉樹遍歷 #include<bits/stdc.h> #define ll long long using namespace std; int n; char show(string s){if(s.find(1)string::npos) return B;if(s.find(0)string::npos) return I;return F; } void dfs(string s){…

FreeRTOS—二值信號量

文章目錄一、二值信號量簡介二、二值信號量相關的API函數2.1.動態方式創建二值信號量2.2.獲取信號量2.3.釋放信號量三、實驗3.1.實驗設計3.2.軟件設計一、二值信號量簡介 二值信號量的本質是一個隊列長度為 1 的隊列&#xff0c;該隊列就只有空和滿兩種情況&#xff0c;也就是…

挖掘錄屏寶藏:Screenity 深度解析與使用指南

挖掘錄屏寶藏&#xff1a;Screenity 深度解析與使用指南 在數字內容創作與信息分享日益頻繁的今天&#xff0c;錄屏軟件成為了眾多創作者、教育者和辦公族的必備工具。今天&#xff0c;我要給大家介紹一款在 GitHub 上收獲了大量關注的開源錄屏軟件 ——Screenity。它功能強大…