確保Web安全的HTTPS--《圖解HTTP》筆記

在HTTP協(xié)議中有可能存在信息竊聽或身份偽裝等安全問題颤绕。使用HTTPS通信機(jī)制可以有效地防止這些問題熬甚。

HTTP的缺點(diǎn)

  • 通信使用明文(不加密)喉酌,內(nèi)容可能會(huì)被竊聽
  • 不驗(yàn)證通信方的身份完箩,因此有可能遭遇偽裝
  • 無(wú)法證明報(bào)文的完整性铁蹈,所以有可能已遭篡改

HTTP+加密+認(rèn)證+完整性保護(hù)=HTTPS

HTTPS是身披SSL外殼的HTTP

HTTPS并非是應(yīng)用層的一種新協(xié)議宽闲。只是HTTP通信接口部分用SSL(Secure Socket Layer)和TLS(Transport Layer Security)協(xié)議代替而已。

通常木缝,HTTP直接和TCP通信便锨。當(dāng)使用SSL時(shí),則演變成先和SSL通信我碟,再由SSL和TCP通信了放案。



在采用SSL后,HTTP就擁有了HTTPS的加密矫俺、證書和完整性功能吱殉。

HTTPS采用混合加密機(jī)制

HTTPS采用共享密鑰加密和公開密鑰加密兩者并用的混合加密機(jī)制。若密鑰能夠?qū)崿F(xiàn)安全交換厘托,那么有可能會(huì)考慮僅使用公開密鑰加密來(lái)通信能真。但是公開密鑰加密與共享密鑰加密相比勇吊,其處理速度要慢延蟹。

所以應(yīng)充分利用兩者各自的優(yōu)勢(shì)每辟,將多種方法組合起來(lái)用于通信。在交換密鑰環(huán)節(jié)使用公開密鑰加密方式包斑,之后的建立通信交換報(bào)文階段則使用共享密鑰加密方式流礁。


證明公開密鑰正確性的證書

如何證明收到的的公開密鑰就是原本預(yù)想的那臺(tái)服務(wù)器發(fā)行的公開密鑰涕俗?為了解決這個(gè)問題,可以使用由數(shù)字證書認(rèn)證機(jī)構(gòu)(CA神帅,Certificate Authority)頒發(fā)的公開密鑰證書再姑。
首先,服務(wù)器的運(yùn)營(yíng)人員向數(shù)字證書認(rèn)證機(jī)構(gòu)提出公開密鑰的申請(qǐng)找御。數(shù)字證書認(rèn)證機(jī)構(gòu)在判明提出申請(qǐng)者的身份之后,會(huì)對(duì)已申請(qǐng)的公開密鑰做數(shù)字簽名霎桅,然后分配這個(gè)已簽名的公開密鑰栖疑,并將該公開密鑰放入公鑰放入公鑰證書后綁定在一起。

服務(wù)器會(huì)將這份由數(shù)字證書認(rèn)證機(jī)構(gòu)頒發(fā)的公鑰證書發(fā)送給客戶端哆档,以進(jìn)行公鑰加密方式通信蔽挠。

接到證書的客戶端可使用數(shù)字證書認(rèn)證機(jī)構(gòu)的公開密鑰,對(duì)那張證書上的數(shù)字簽名進(jìn)行驗(yàn)證雇寇,一旦驗(yàn)證通過锨侯,客戶端便可明確兩件事:一,認(rèn)證服務(wù)器的公開密鑰的是真實(shí)有效的數(shù)字證書認(rèn)證機(jī)構(gòu)冬殃。二囚痴,服務(wù)器的公開密鑰是值得信賴的审葬。

多數(shù)瀏覽器開發(fā)商發(fā)布版本時(shí)深滚,會(huì)事先在內(nèi)部植入常用認(rèn)證機(jī)構(gòu)的公開密鑰。


證書.png

HTTPS的安全通信機(jī)制

https通信.png

步驟1:客戶端通過發(fā)送Client Hello報(bào)文開始SSL通信涣觉。報(bào)文中包含客戶端支持的SSL的指定版本痴荐、加密組件(Cipher Sutie)列表(所有使用的加密算法及密鑰長(zhǎng)度等)。

步驟2:服務(wù)器可進(jìn)行SSL通信時(shí)官册,會(huì)以Server Hello報(bào)文作為應(yīng)答生兆。和客戶端一樣,在報(bào)文中包含SSL版本以及加密組件膝宁。服務(wù)器的加密組件內(nèi)容從接收到的客戶端加密組件內(nèi)篩選出來(lái)的鸦难。

步驟3:之后服務(wù)器發(fā)送Certificate報(bào)文栖榨。報(bào)文中包含公開密鑰證書。

步驟4:最后服務(wù)器發(fā)送Server Hello Done報(bào)文通知客戶端明刷,最初階段的SSL握手協(xié)商部分結(jié)束婴栽。

步驟5:SSL第一次握手結(jié)束之后,客戶端以Client Key Exchange報(bào)文作為回應(yīng)辈末。報(bào)文中包含通信加密中使用的一種被稱為Pre-master secret的隨機(jī)密碼串愚争。該報(bào)文已用步驟3中的公開密鑰進(jìn)行加密。

步驟6:接著客戶端繼續(xù)發(fā)送Change Cipher Spec報(bào)文挤聘。該報(bào)文會(huì)提示服務(wù)器轰枝,在此報(bào)文之后的通信會(huì)采用Pre-master secret密鑰加密。

步驟7:客戶端發(fā)送Finished報(bào)文组去。該報(bào)文包含連接至今全部報(bào)文的整體校驗(yàn)值鞍陨。

步驟8:服務(wù)器同樣發(fā)送Change Cipher Spec報(bào)文。

步驟9:服務(wù)器同樣發(fā)送Finished報(bào)文从隆。

步驟10:服務(wù)器和客戶端的Finished報(bào)文交換完畢后诚撵,SSL連接就算建立完成。從此處開始進(jìn)行應(yīng)用層協(xié)議的通信键闺,即發(fā)送HTTP請(qǐng)求寿烟。

步驟11:應(yīng)用層協(xié)議通信,即發(fā)送HTTP響應(yīng)辛燥。

步驟12:最后由客戶端斷開連接筛武。

在以上流程中,應(yīng)用層發(fā)送數(shù)據(jù)時(shí)會(huì)附加一種叫做MAC(Message Authentication Code)的報(bào)文摘要挎塌。MAC能夠查知報(bào)文是否遭到篡改徘六。

為什么不一直使用HTTPS

因?yàn)榕c純文本通信相比,加密通信會(huì)消耗更多的CPU及內(nèi)存資源榴都。如果每次通信都加密待锈,會(huì)消耗相當(dāng)多的資源。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末缭贡,一起剝皮案震驚了整個(gè)濱河市炉擅,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌阳惹,老刑警劉巖谍失,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異莹汤,居然都是意外死亡快鱼,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)抹竹,“玉大人线罕,你說(shuō)我怎么就攤上這事∏耘校” “怎么了钞楼?”我有些...
    開封第一講書人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)袄琳。 經(jīng)常有香客問我询件,道長(zhǎng),這世上最難降的妖魔是什么唆樊? 我笑而不...
    開封第一講書人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任宛琅,我火速辦了婚禮,結(jié)果婚禮上逗旁,老公的妹妹穿的比我還像新娘嘿辟。我一直安慰自己,他們只是感情好片效,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開白布红伦。 她就那樣靜靜地躺著,像睡著了一般堤舒。 火紅的嫁衣襯著肌膚如雪色建。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評(píng)論 1 285
  • 那天舌缤,我揣著相機(jī)與錄音,去河邊找鬼某残。 笑死国撵,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的玻墅。 我是一名探鬼主播介牙,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼澳厢!你這毒婦竟也來(lái)了环础?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤剩拢,失蹤者是張志新(化名)和其女友劉穎线得,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體徐伐,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡贯钩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片角雷。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡祸穷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出勺三,到底是詐尸還是另有隱情雷滚,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布吗坚,位于F島的核電站揭措,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏刻蚯。R本人自食惡果不足惜绊含,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望炊汹。 院中可真熱鬧躬充,春花似錦、人聲如沸讨便。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)霸褒。三九已至伴找,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間废菱,已是汗流浹背技矮。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留殊轴,地道東北人衰倦。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像旁理,于是被迫代替她去往敵國(guó)和親樊零。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容