https協議詳解

2021-07-04 19:48:03 字數 1180 閱讀 8842

ssl (secure socket layer)

https(secure hypertext transfer protocol)安全超文字傳輸協議

https解決的問題: 

1 . 信任主機的問題. 採用https 的server 必須從ca 申請乙個用於證明伺服器用途型別的證書. 改證書只有用於對應的server 的時候,客戶度才信任次主機. 所以目前所有的銀行系統**,關鍵部分應用都是https 的. 客戶通過信任該證書,從而信任了該主機. 其實這樣做效率很低,但是銀行更側重安全. 這一點對我們沒有任何意義,我們的server ,採用的證書不管自己issue 還是從公眾的地方issue, 客戶端都是自己人,所以我們也就肯定信任該server.

2 . 通訊過程中的資料的洩密和被竄改 

1. 一般意義上的https, 就是 server 有乙個證書. 

a) 主要目的是保證server 就是他聲稱的server. 這個跟第一點一樣. 

b) 服務端和客戶端之間的所有通訊,都是加密的. 

i. 具體講,是客戶端產生乙個對稱的金鑰,通過server 的證書來交換金鑰. 一般意義上的握手過程. 

ii. 加下來所有的資訊往來就都是加密的. 第三方即使截獲,也沒有任何意義.因為他沒有金鑰. 當然竄改也就沒有什麼意義了.

2. 少許對客戶端有要求的情況下,會要求客戶端也必須有乙個證書. 

a) 這裡客戶端證書,其實就類似表示個人資訊的時候,除了使用者名稱/密碼, 還有乙個ca 認證過的身份. 應為個人證書一般來說上別人無法模擬的,所有這樣能夠更深的確認自己的身份.

b) 目前少數個人銀行的專業版是這種做法,具體證書可能是拿u盤作為乙個備份的載體.

https 一定是繁瑣的. 

a) 本來簡單的http協議,乙個get乙個response. 由於https 要還金鑰和確認加密演算法的需要.單握手就需要6/7 個往返. 

i. 任何應用中,過多的round trip 肯定影響效能. 

b) 接下來才是具體的http協議,每一次響應或者請求, 都要求客戶端和服務端對會話的內容做加密/解密. 

i. 儘管對稱加密/解密效率比較高,可是仍然要消耗過多的cpu,為此有專門的ssl 晶元. 如果cpu 信能比較低的話,肯定會降低效能,從而不能serve 更多的請求.

ii. 加密後資料量的影響. 所以,才會出現那麼多的安全認證提示

https協議詳解

ssl secure socket layer https secure hypertext transfer protocol 安全超文字傳輸協議 https解決的問題 1 信任主機的問題.採用https 的server 必須從ca 申請乙個用於證明伺服器用途型別的證書.改證書只有用於對應的ser...

HTTPS協議詳解

https 全稱 hypertext transfer protocol over secure socket layer 其實https並不是乙個新鮮協議,google很早就開始啟用了,初衷是為了保證資料安全。近些年,google baidu facebook等這樣的網際網路巨頭,不謀而合地開始大...

HTTPS協議詳解 三 PKI 體系

1 rsa身份驗證的隱患 身份驗證和金鑰協商是tls的基礎功能,要求的前提是合法的伺服器掌握著對應的私鑰。但rsa演算法無法確保伺服器身份的合法性,因為公鑰並不包含伺服器的資訊,存在安全隱患 客戶端c和伺服器s進行通訊,中間節點m截獲了二者的通訊 節點m自己計算產生一對公鑰pub m和私鑰pri m...