成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

字節(jié)一面:HTTPS 會(huì)加密 URL 嗎?

網(wǎng)絡(luò) 無線技術(shù) 數(shù)據(jù)安全
因?yàn)?URL 的信息都是保存在 HTTP Header 中的,而 HTTPS 是會(huì)對(duì) HTTP Header + HTTP Body 整個(gè)加密的,所以 URL 自然是會(huì)被加密的。

大家好,我是小林,昨晚有位讀者又給我送素材來了。

他在面試字節(jié),被問到這個(gè)問題:HTTPS 會(huì)加密 URL 嗎?

圖片

圖片

?

答案是,會(huì)加密的。

因?yàn)?URL 的信息都是保存在 HTTP Header 中的,而 HTTPS 是會(huì)對(duì) HTTP Header + HTTP Body 整個(gè)加密的,所以 URL 自然是會(huì)被加密的。

下圖是 HTTP/1.1 的請(qǐng)求頭部,可以看到是包含 URL 信息的。

圖片

對(duì)應(yīng)的實(shí)際的 HTTP/1.1 的請(qǐng)求頭部:

圖片

HTTP/1.1 請(qǐng)求的第一行包含請(qǐng)求方法和路徑。HTTP/2 用一系列偽頭部(pseudo-header)替換了請(qǐng)求行,這五個(gè)偽頭部很容易識(shí)別,因?yàn)樗鼈冊(cè)诿Q的開頭用了一個(gè)冒號(hào)來表示。

比如請(qǐng)求方法和路徑偽頭字段如下:

  • ":method" 偽頭字段包含了 HTTP 方法;
  • ":path" 偽頭字段包含目標(biāo) URL 的路徑和查詢部分;

如下圖:

圖片

上圖是我瀏覽器 F12 開發(fā)者工具查看的信息,瀏覽器顯示信息是已經(jīng)解密后的信息,所以不要誤以為 URL 沒有加密。

如果你用抓包工具,抓包 HTTPS 的數(shù)據(jù)的話,你是什么都看不到的,如下圖,只會(huì)顯示“Application Data”,表示這是一個(gè)已經(jīng)加密的 HTTP 應(yīng)用數(shù)據(jù)。

圖片

HTTPS 可以看到域名嗎?

再問大家一個(gè)問題,HTTPS 可以看到請(qǐng)求的域名嗎?

從上面我們知道,HTTPS 是已經(jīng)把  HTTP Header + HTTP Body 整個(gè)加密的,所以我們是無法從加密的 HTTP 數(shù)據(jù)中獲取請(qǐng)求的域名的。

但是我們可以在 TLS 握手過程中看到域名信息。

比如下圖,TLS 第一次握手的 “Client Hello” 消息中,有個(gè) server name 字段,它就是請(qǐng)求的域名地址。

圖片

所以,用了 HTTPS 也不能以為偷偷在公司上某 hub 不會(huì)被發(fā)現(xiàn)。

HTTPS 的應(yīng)用數(shù)據(jù)是如何保證完整性的?

TLS 的握手協(xié)議我相信大家都很熟悉了,我也寫過相關(guān)的文章了:

然后對(duì)于 HTTPS 是怎么加密 HTTP 數(shù)據(jù)的,我沒有提到過。

然后很多讀者以為 HTTP 數(shù)據(jù)就用對(duì)稱加密密鑰(TLS 握手過程中協(xié)商出來的對(duì)稱加密密鑰)加密后就直接發(fā)送了,然后就疑惑 HTTP 數(shù)據(jù)有沒有通過摘要算法來保證完整性?

事實(shí)上,TLS 在實(shí)現(xiàn)上分為握手協(xié)議和記錄協(xié)議兩層:

  • TLS 握手協(xié)議就是我們說的 TLS 四次握手的過程,負(fù)責(zé)協(xié)商加密算法和生成對(duì)稱密鑰,后續(xù)用此密鑰來保護(hù)應(yīng)用程序數(shù)據(jù)(即 HTTP 數(shù)據(jù));
  • TLS 記錄協(xié)議負(fù)責(zé)保護(hù)應(yīng)用程序數(shù)據(jù)并驗(yàn)證其完整性和來源,所以對(duì) HTTP 數(shù)據(jù)加密是使用記錄協(xié)議;

TLS 記錄協(xié)議主要負(fù)責(zé)消息(HTTP 數(shù)據(jù))的壓縮,加密及數(shù)據(jù)的認(rèn)證,過程如下圖:

圖片

具體過程如下:

  • 首先,消息被分割成多個(gè)較短的片段,然后分別對(duì)每個(gè)片段進(jìn)行壓縮。
  • 接下來,經(jīng)過壓縮的片段會(huì)被加上消息認(rèn)證碼(MAC 值,這個(gè)是通過哈希算法生成的),這是為了保證完整性,并進(jìn)行數(shù)據(jù)的認(rèn)證。通過附加消息認(rèn)證碼的 MAC 值,可以識(shí)別出篡改。與此同時(shí),為了防止重放攻擊,在計(jì)算消息認(rèn)證碼時(shí),還加上了片段的編碼。
  • 再接下來,經(jīng)過壓縮的片段再加上消息認(rèn)證碼會(huì)一起通過對(duì)稱密碼進(jìn)行加密。
  • 最后,上述經(jīng)過加密的數(shù)據(jù)再加上由數(shù)據(jù)類型、版本號(hào)、壓縮后的長(zhǎng)度組成的報(bào)頭就是最終的加密報(bào)文數(shù)據(jù)。

記錄協(xié)議完成后,最終的加密報(bào)文數(shù)據(jù)將傳遞到傳輸控制協(xié)議 (TCP) 層進(jìn)行傳輸。

責(zé)任編輯:趙寧寧 來源: 小林coding
相關(guān)推薦

2022-08-18 17:44:25

HTTPS協(xié)議漏洞

2024-09-19 08:51:01

HTTP解密截取

2022-03-30 10:10:17

字節(jié)碼棧空間

2024-11-26 08:52:34

SQL優(yōu)化Kafka

2022-10-10 08:13:16

遞歸通用代碼

2022-05-10 22:00:41

UDPTCP協(xié)議

2022-01-05 21:54:51

網(wǎng)絡(luò)分層系統(tǒng)

2022-06-01 11:52:42

網(wǎng)站客戶端網(wǎng)絡(luò)

2024-11-11 10:34:55

2022-11-30 17:13:05

MySQLDynamic存儲(chǔ)

2022-07-26 00:00:02

TCPUDPMAC

2022-05-11 22:15:51

云計(jì)算云平臺(tái)

2022-10-19 14:08:42

SYNTCP報(bào)文

2022-12-13 18:09:25

連接狀態(tài)客戶端

2024-03-18 08:21:06

TCPUDP協(xié)議

2024-05-15 16:41:57

進(jìn)程IO文件

2025-04-15 08:00:00

Java開發(fā)服務(wù)網(wǎng)格

2024-09-04 15:17:23

2022-12-02 13:49:41

2024-03-05 10:07:22

TCPUDP協(xié)議
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 香蕉超碰| 中文字幕精品一区二区三区精品 | 高清黄色毛片 | 国产美女特级嫩嫩嫩bbb片 | 日日射夜夜骑 | 草草草草视频 | 一二区视频 | 亚洲免费高清 | 91精品在线播放 | 国产做a爱片久久毛片 | 久久国产精品偷 | www.久久99| 日日骚av | 国产精品一区视频 | 精品在线一区 | 综合自拍 | 日本一区二区视频 | 美女一级a毛片免费观看97 | 日本久久精品视频 | 午夜免费视频 | 日韩乱码在线 | 中文久久| 国产日韩欧美激情 | 国产一区2区 | 午夜三级视频 | 国产精品亚洲片在线播放 | 精品一区二区三区av | 天天操网| 欧美日韩国产精品一区 | 成人精品福利 | 99re在线视频 | 日本一区二区三区精品视频 | 97精品一区二区 | 成av人电影在线 | 视频在线一区 | 日韩精品视频一区二区三区 | 免费观看www| 成人在线精品视频 | 久久小视频 | 国产精品久久在线观看 | 久久专区 |