超文本傳輸協(xié)議花墩,HTTP協(xié)議被用于在Web瀏覽器和網站服務器之間傳遞信息天梧,HTTP協(xié)議以明文方式發(fā)送內容劫灶,不提供任何方式的數據加密,如果攻擊者截取了Web瀏覽器和網站服務器之間的傳輸報文扔嵌,就可以直接讀懂其中的信息限府,因此夺颤,HTTP協(xié)議不適合傳輸一些敏感信息,比如:信用卡號胁勺、密碼等支付信息世澜。
為了解決HTTP協(xié)議的這一缺陷,需要使用另一種協(xié)議:安全套接字層超文本傳輸協(xié)議HTTPS署穗,為了數據傳輸的安全寥裂,HTTPS在HTTP的基礎上加入了SSL協(xié)議,SSL依靠證書來驗證服務器的身份案疲,并為瀏覽器和服務器之間的通信加密封恰。
一、HTTP和HTTPS的基本概念
HTTP:是互聯(lián)網上應用最為廣泛的一種網絡協(xié)議络拌,是一個客戶端和服務器端請求和應答的標準(TCP)俭驮,用于從WWW服務器傳輸超文本到本地瀏覽器的傳輸協(xié)議,它可以使瀏覽器更加高效春贸,使網絡傳輸減少混萝。
HTTPS:是以安全為目標的HTTP通道,簡單講是HTTP的安全版萍恕,即HTTP下加入SSL層逸嘀,HTTPS的安全基礎是SSL,因此加密的詳細內容就需要SSL允粤。
HTTPS協(xié)議的主要作用可以分為兩種:一種是建立一個信息安全通道崭倘,來保證數據傳輸的安全;另一種就是確認網站的真實性类垫。
二司光、HTTP與HTTPS有什么區(qū)別?
HTTP協(xié)議傳輸的數據都是未加密的悉患,也就是明文的残家,因此使用HTTP協(xié)議傳輸隱私信息非常不安全,為了保證這些隱私數據能加密傳輸售躁,于是網景公司設計了SSL(Secure Sockets Layer)協(xié)議用于對HTTP協(xié)議傳輸的數據進行加密坞淮,從而就誕生了HTTPS。簡單來說陪捷,HTTPS協(xié)議是由SSL+HTTP協(xié)議構建的可進行加密傳輸回窘、身份認證的網絡協(xié)議,要比http協(xié)議安全市袖。
HTTPS和HTTP的區(qū)別主要如下:
1啡直、https協(xié)議需要到ca申請證書,一般免費證書較少,因而需要一定費用付枫。
2烹玉、http是超文本傳輸協(xié)議驰怎,信息是明文傳輸阐滩,https則是具有安全性的ssl加密傳輸協(xié)議。
3县忌、http和https使用的是完全不同的連接方式掂榔,用的端口也不一樣,前者是80症杏,后者是443装获。
4替饿、http的連接很簡單毅哗,是無狀態(tài)的蓬戚;HTTPS協(xié)議是由SSL+HTTP協(xié)議構建的可進行加密傳輸解取、身份認證的網絡協(xié)議西饵,比http協(xié)議安全揉稚。
三妄呕、HTTPS的工作原理
我們都知道HTTPS能夠加密信息潜慎,以免敏感信息被第三方獲取帜乞,所以很多銀行網站或電子郵箱等等安全級別較高的服務都會采用HTTPS協(xié)議司抱。
客戶端在使用HTTPS方式與Web服務器通信時有以下幾個步驟,如圖所示黎烈。
∠澳(1)客戶使用https的URL訪問Web服務器,要求與Web服務器建立SSL連接照棋。
∽世!(2)Web服務器收到客戶端請求后,會將網站的證書信息(證書中包含公鑰)傳送一份給客戶端烈炭。
∪芏А(3)客戶端的瀏覽器與Web服務器開始協(xié)商SSL連接的安全等級,也就是信息加密的等級梳庆。
∨尽(4)客戶端的瀏覽器根據雙方同意的安全等級,建立會話密鑰膏执,然后利用網站的公鑰將會話密鑰加密驻售,并傳送給網站。
「住(5)Web服務器利用自己的私鑰解密出會話密鑰欺栗。
(6)Web服務器利用會話密鑰加密與客戶端之間的通信。
四迟几、HTTPS的優(yōu)點
盡管HTTPS并非絕對安全消请,掌握根證書的機構、掌握加密算法的組織同樣可以進行中間人形式的攻擊类腮,但HTTPS仍是現(xiàn)行架構下最安全的解決方案臊泰,主要有以下幾個好處:
(1)使用HTTPS協(xié)議可認證用戶和服務器蚜枢,確保數據發(fā)送到正確的客戶機和服務器缸逃;
(2)HTTPS協(xié)議是由SSL+HTTP協(xié)議構建的可進行加密傳輸厂抽、身份認證的網絡協(xié)議需频,要比http協(xié)議安全,可防止數據在傳輸過程中不被竊取筷凤、改變昭殉,確保數據的完整性。
∶晔亍(3)HTTPS是現(xiàn)行架構下最安全的解決方案挪丢,雖然不是絕對安全,但它大幅增加了中間人攻擊的成本吗伤。
〕钥俊(4)谷歌曾在2014年8月份調整搜索引擎算法,并稱“比起同等HTTP網站足淆,采用HTTPS加密的網站在搜索結果中的排名將會更高”巢块。
五、HTTPS的缺點
雖然說HTTPS有很大的優(yōu)勢巧号,但其相對來說族奢,還是存在不足之處的:
(1)HTTPS協(xié)議握手階段比較費時丹鸿,會使頁面的加載時間延長近50%越走,增加10%到20%的耗電;
】炕丁(2)HTTPS連接緩存不如HTTP高效廊敌,會增加數據開銷和功耗,甚至已有的安全措施也會因此而受到影響门怪;
÷獬骸(3)SSL證書需要錢,功能越強大的證書費用越高掷空,個人網站肋殴、小網站沒有必要一般不會用囤锉。
? (4)SSL證書通常需要綁定IP,不能在同一IP上綁定多個域名护锤,IPv4資源不可能支撐這個消耗官地。
(5)HTTPS協(xié)議的加密范圍也比較有限烙懦,在黑客攻擊驱入、拒絕服務攻擊、服務器劫持等方面幾乎起不到什么作用修陡。最關鍵的沧侥,SSL證書的信用鏈體系并不安全可霎,特別是在某些國家可以控制CA根證書的情況下魄鸦,中間人攻擊一樣可行。
六癣朗、http切換到HTTPS
如果需要將網站從http切換到https到底該如何實現(xiàn)呢拾因?
? ? ?這里需要將頁面中所有的鏈接,例如js旷余,css绢记,圖片等等鏈接都由http改為https。例如:http://www.baidu.com改為https://www.baidu.com
BTW正卧,這里雖然將http切換為了https蠢熄,還是建議保留http。所以我們在切換的時候可以做http和https的兼容炉旷,具體實現(xiàn)方式是签孔,去掉頁面鏈接中的http頭部,這樣可以自動匹配http頭和https頭窘行。例如:將http://www.baidu.com改為//www.baidu.com饥追。然后當用戶從http的入口進入訪問頁面時,頁面就是http罐盔,如果用戶是從https的入口進入訪問頁面但绕,頁面即使https的。