Http和Https的區別?

来源:https://www.cnblogs.com/python1111/archive/2022/11/16/16897476.html
-Advertisement-
Play Games

1.HTTP是什麼? http是超文本傳輸協議用來在web瀏覽器和網站伺服器之間傳遞數據信息,http以明文的方式發送內容,不提供任何方式的數據加密,如果攻擊者截獲了Web瀏覽器和網站伺服器之間的傳輸報文,就可以直接讀懂其中的信息,因此,HTTP協議不適合傳輸一些敏感信息,比如:信用卡號、密碼等支付 ...


1.HTTP是什麼?

http是超文本傳輸協議用來在web瀏覽器和網站伺服器之間傳遞數據信息,http以明文的方式發送內容,不提供任何方式的數據加密,如果攻擊者截獲了Web瀏覽器和網站伺服器之間的傳輸報文,就可以直接讀懂其中的信息,因此,HTTP協議不適合傳輸一些敏感信息,比如:信用卡號、密碼等支付信息。
為瞭解決http協議的這一缺陷,需要使用另一種協議:安全套接字層超文本傳輸協議HTTPS,為了數據傳輸的安全,https在http的基礎上加入了SSL協議,ssl依靠證書來驗證伺服器的身份,併為瀏覽器和伺服器之間的通信加密。

2.HTTP和HTTPS的基本概念

HTTP:是互聯網上應用最為廣泛的一種網路協議,是一個客戶端和伺服器端請求和應答的標準(tcp),用於從www伺服器傳輸超文本到本地瀏覽器的傳輸協議,他可以使瀏覽器更加高效,使網路傳輸減少
HTTPS:是以安全為目的HTTP通道,簡單講是HTTP的安全版,即HTTP下加入SSL層,HTTPS的安全基礎是SSL,因此加密的詳細內容就是需要SSL
HTTPS協議的主要作用可以分為兩種:一種是建立一個信息安全通道,來保證數據傳輸的安全;另一種就是確認網路的真實性。

3.HTTP與HTTPS有什麼區別?

HTTP協議傳輸的數據都是未加密的,也就是明文的,因此使用HTTP協議傳輸隱私信息非常不安全,為了保證這些隱私數據能加密傳輸,於是網景公司設計了SSL協議,用於對HTTP協議傳輸的數據進行加密,從而就誕生了HTTPS。簡單來說,HTTPS協議是由SSL+HTTP協議構建的可進行加密傳輸、身份認證的網路協議,要不HTTP協議安全。
HTTP和HTTPS的主要區別如下:
1.https協議需要到ca申請證書,一般免費證書較少,因而需要一定費用
2.http是超文本傳輸協議,信息是明文傳輸,https則是具有安全行的ssl加密傳輸協議。
3.完全不同的連接方式,http使用了TCP方式連接,而https使用了UDP方式連接,用的埠也不一樣,前者是80,後者是443
4.http的連接很簡單,是無狀態的;HTTPS協議是有SSL+HTTP協議構建的可進行加密傳輸、身份認證的網路協議,比http協議安全。

4.HTTPS的工作原理

我們都知道了HTTPS能夠加密信息,以免敏感信息被第三方獲取,所以很多銀行網站或電子郵箱等安全級別較高的服務都會採用HTTPS協議
客戶端在使用HTTPS方式與WEB伺服器通信時有以下幾個步驟:

  1. 客戶使用https的URL訪問web伺服器,要求與web伺服器建立SSL連接
  2. web伺服器收到客戶端請求後,會將網站的證書信息(證書中包含公鑰)傳送一份給客戶端
  3. 客戶端的瀏覽器與WEB伺服器開始協商SSL連接的安全等級,也就是信息加密的等級
  4. 客戶端的瀏覽器根據雙方同意的安全等級,建立會話秘鑰,然後利用網站的公鑰將會話秘鑰加密,並傳送給網站
  5. web伺服器利用自己的私鑰解密出會話秘鑰
  6. web伺服器利用會話秘鑰加密與客戶端之間的通信

5.HTTPS的優點

儘管HTTPS並非絕對安全,掌管根證書的機構、掌握加密演算法的組織同樣可以進行中間人形式的攻擊,但HTTPS仍是現行架構下最安全的解決方案,主要有以下好處:

  1. 使用HTTPS協議可認證用戶和伺服器,確保數據發送到正確的客戶機和伺服器;
  2. HTTPS協議是由SSL+HTTP協議構建的可進行加密傳輸、身份認證的網路協議,要比http協議安全,可防止數據在傳輸過程中不被竊取、改變,確保數據的完整性。
  3. HTTPS是現行架構下最安全的解決方案,雖然不是絕對安全,但它大幅增加了中間人攻擊的成本。
  4. 谷歌曾在2014年8月份調整搜索引擎演算法,並稱“比起同等HTTP網站,採用HTTPS加密的網站在搜索結果中的排名將會更高”

6.HTTPS的缺點

雖然說HTTPS有很大的優勢,但其相對來說,還是存在不足之處的:

  1. HTTPS協議握手階段比較費時,會使頁面的載入時間延長近50%,增加10%到20%的耗電;
  2. HTTPS連接緩存不如HTTP高效,會增加數據開銷和功耗,甚至已有的安全措施也會因此而受到影響;
  3. SSL證書需要錢,功能越強大的證書費用越高,個人網站、小網站沒有必要一般不會用。
  4. SSL證書通常需要綁定IP,不能在同一IP上綁定多個功能變數名稱,IPv4資源不可能支撐這個消耗。
  5. HTTPS協議的加密範圍也比較有限,在黑客攻擊、拒絕服務攻擊、伺服器劫持等方面幾乎起不到什麼作用。最關鍵的,SSL證書的信用鏈體系並不安全,特別是在某些國家可以控制CA根證書的情況下,中間人攻擊一樣可行。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 5.2 文件處理策略 在開發fastDFS和minio實現類之前,需要提前安裝部署好fastDFS和minio。搭建教程可參考前面的章節。 第2-1-2章 傳統方式安裝FastDFS-附FastDFS常用命令 第2-1-3章 docker-compose安裝FastDFS,實現文件存儲服務 第2-1 ...
  • 1、UML統一建模語言 定義:用於軟體系統設計與分析的語言工具 目的:幫助開發人員更好的梳理邏輯、思路 學習地址:UML概述_w3cschool 官網:https://www.omg.org/spec/UML 1.1、UML組成結構 flowchart TD; UML圖 --> 結構圖 & 行為圖; ...
  • 概述 github、gitee中,fork後的倉庫不會自動同步源倉庫。可以通過設置遠程同步源的方式來拉取源倉庫代碼。 查看遠程倉庫 git remote -v 設置upstream上游倉庫 設置源倉庫地址 git remote add upstream https://gitee.com/xxxxx ...
  • 實現01 1.實現任務階段1 編寫mytomcat,該伺服器能給瀏覽器返回“你好,我是伺服器!”的簡單信息。 根據之前的tomcat框架整體分析,我們將瀏覽器發送請求,tomcat伺服器處理請求,返回資源的整個過程分為三個部分。現在來分析並初步實現第一部分的功能。 1.1基於socket開發服務端流 ...
  • 1.range # 1.range(起始值,結束值,步長) # 範圍 區間 # 步長不寫時預設是1 # 當裡面只有一個數據的時候,預設是0-結束值 # 當裡面有兩個數據的時候,是 起始值-結束值 print('1.range()') print(range(5, 9, 1)) print(type( ...
  • 生成器是一種特殊的迭代器,也可以說其父類型是迭代器 1、迭代器其實也有很多點要清楚,這裡先不做贅述 2、要清楚,迭代器調用iter()返回的是自身 1 def func(s, e): 2 """ 3 生成器函數 4 :param s:起始值 5 :param e: 末值 6 :return: 7 " ...
  • scanf在vs2022中是一個不安全的函數,vs自定義scanf_s是一個安全的函數,但是這在轉給其他編譯器可能不適用 我們可以在開頭加上一個#define _CRT_SECURE_NO_WARNINGS 1可以解決問題 但是自己打比較麻煩,這個時候我們可以打開vs編譯器的文件然後找到VC這個文件 ...
  • 平常是處理文字的時候更多用到的是字元串方面的工具類,作為學習漢字的工具,拼音還是很重要的一個輔助方式,分享一個漢字轉拼音的工具類。可以用於幫助學習漢字或者作為一些漢字的輔助說明都也是可以的。這個還支持將漢字拼音輸出為首字母,例如"愷龍"可以輸出為"kl",在現在大家很多時候都用縮寫的情況下,可以也可 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...