HTTP1.0,HTTP1.1,HTTPS和HTTP2.0的区别
HTTP1.0和HTTP1.1的一些區(qū)別
緩存處理,在HTTP1.0中主要使用header里的If-Modified-Since,Expires來做為緩存判斷的標準,HTTP1.1則引入了更多的緩存控制策略例如Entity tag,If-Unmodified-Since, If-Match, If-None-Match等更多可供選擇的緩存頭來控制緩存策略。
帶寬優(yōu)化及網(wǎng)絡(luò)連接的使用,HTTP1.0中,存在一些浪費帶寬的現(xiàn)象,例如客戶端只是需要某個對象的一部分,而服務(wù)器卻將整個對象送過來了,并且不支持斷點續(xù)傳功能,HTTP1.1則在請求頭引入了range頭域,它允許只請求資源的某個部分,即返回碼是206(Partial Content),這樣就方便了開發(fā)者自由的選擇以便于充分利用帶寬和連接。 錯誤通知的管理,在HTTP1.1中新增了24個錯誤狀態(tài)響應(yīng)碼,如409(Conflict)表示請求的資源與資源的當前狀態(tài)發(fā)生沖突;410(Gone)表示服務(wù)器上的某個資源被永久性的刪除。
Host頭處理,在HTTP1.0中認為每臺服務(wù)器都綁定一個唯一的IP地址,因此,請求消息中的URL并沒有傳遞主機名(hostname)。但隨著虛擬主機技術(shù)的發(fā)展,在一臺物理服務(wù)器上可以存在多個虛擬主機(Multi-homed Web Servers),并且它們共享一個IP地址。HTTP1.1的請求消息和響應(yīng)消息都應(yīng)支持Host頭域,且請求消息中如果沒有Host頭域會報告一個錯誤(400 Bad Request)。
長連接,HTTP 1.1支持長連接(PersistentConnection)和請求的流水線(Pipelining)處理,在一個TCP連接上可以傳送多個HTTP請求和響應(yīng),減少了建立和關(guān)閉連接的消耗和延遲,在HTTP1.1中默認開啟Connection: keep-alive,一定程度上彌補了HTTP1.0每次請求都要創(chuàng)建連接的缺點。
HTTP1.0和1.1現(xiàn)存的一些問題
HTTP1.x在傳輸數(shù)據(jù)時,每次都需要重新建立連接,無疑增加了大量的延遲時間,特別是在移動端更為突出。
HTTP1.x在傳輸數(shù)據(jù)時,所有傳輸?shù)膬?nèi)容都是明文,客戶端和服務(wù)器端都無法驗證對方的身份,這在一定程度上無法保證數(shù)據(jù)的安全性。
HTTP1.x在使用時,header里攜帶的內(nèi)容過大,在一定程度上增加了傳輸?shù)某杀?#xff0c;并且每次請求header基本不怎么變化,尤其在移動端增加用戶流量。
雖然HTTP1.x支持了keep-alive,來彌補多次創(chuàng)建連接產(chǎn)生的延遲,但是keep-alive使用多了同樣會給服務(wù)端帶來大量的性能壓力,并且對于單個文件被不斷請求的服務(wù)(例如圖片存放網(wǎng)站),keep-alive可能會極大的影響性能,因為它在文件被請求之后還保持了不必要的連接很長時間。
HTTPS與HTTP的一些區(qū)別
HTTPS協(xié)議需要到CA申請證書,一般免費證書很少,需要交費。
HTTP協(xié)議運行在TCP之上,所有傳輸?shù)膬?nèi)容都是明文,HTTPS運行在SSL/TLS之上,SSL/TLS運行在TCP之上,所有 傳輸?shù)膬?nèi)容都經(jīng)過加密的。
HTTP和HTTPS使用的是完全不同的連接方式,用的端口也不一樣,前者是80,后者是443。
HTTPS可以有效的防止運營商劫持,解決了防劫持的一個大問題。
HTTP2.0的新特性
新的二進制格式(Binary Format),HTTP1.x的解析是基于文本。基于文本協(xié)議的格式解析存在天然缺陷,文本的表現(xiàn)形式有多樣性,要做到健壯性考慮的場景必然很多,二進制則不同,只認0和1的組合。基于這種考慮HTTP2.0的協(xié)議解析決定采用二進制格式,實現(xiàn)方便且健壯。
多路復(fù)用(MultiPlexing),即連接共享,即每一個request都是是用作連接共享機制的。一個request對應(yīng)一個id,這樣一個連接上可以有多個request,每個連接的request可以隨機的混雜在一起,接收方可以根據(jù)request的 id將request再歸屬到各自不同的服務(wù)端請求里面。
header壓縮,如上文中所言,對前面提到過HTTP1.x的header帶有大量信息,而且每次都要重復(fù)發(fā)送,HTTP2.0使用encoder來減少需要傳輸?shù)膆eader大小,通訊雙方各自cache一份header fields表,既避免了重復(fù)header的傳輸,又減小了需要傳輸?shù)拇笮 ?/p>
服務(wù)端推送(server push),HTTP2.0具有server push功能。
轉(zhuǎn)載于:https://juejin.im/post/5cb59890f265da03b8584603
總結(jié)
以上是生活随笔為你收集整理的HTTP1.0,HTTP1.1,HTTPS和HTTP2.0的区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LeetCode每日一题: 单值二叉树(
- 下一篇: 智造制造的AI之路