總括:前端
博主博客地址:Damonare的我的博客瀏覽器
生活安全
只要你聽過HTTPS,不可能沒聽過SSL協議吧,SSL協議是一種安全協議。對於互聯網協議沒有了解的童鞋能夠參考博主另外一篇博客:internet協議入門服務器
HTTP+SSL = HTTPSdom
HTTPS之因此安全就是由於加持了SSL這個外掛來對傳輸的數據進行加密,那麼具體的加密方法又是什麼呢?加密
請聽我娓娓道來。先看下面兩個概念:blog
對稱加密ip
非對稱加密ssl
你知道上面兩個概念是什麼意思麼?😳
🤣OK,無論你懂不懂,我先用個人方式來給你解釋下:
親,你做過弊麼?😑不要告訴我在你漫長的學生生涯裏你沒做過弊(那你的學生生涯得多枯燥),做弊咱們經常使用的方法是啥?(說把答案寫在胳膊大腿紙條上的同窗請你出去,謝謝🙂)固然是加密了!好比我出於人道主義,想要幫助小明同窗做弊,首先考試前咱們會約定好一個暗號來傳遞選擇題的答案,摸頭髮——A,摸耳朵——B,咳嗽——C,跺腳——D,因而一個加密方法就誕生了,這個加密方法只有我和小明知道,老師雖然看我抓耳撓腮但他頂多把我當成神經病,並無直接證聽說我做弊。好,這種我和小明知道,別人不知道的加密方法就是一種對稱加密算法,對稱加密算法也是咱們平常最多見的加密算法。這種算法🔑只有一把,加密解密都用同一把鑰匙,一旦🔑泄露就全玩完了。
隨時時代的進步,人們發現實際上加密和解密不用同一把🔑也是能夠的,只要加密和解密的兩把🔑存在某種關係就好了。
因而,層出不窮的非對稱加密算法就被研究了出來,那麼它基於什麼樣的道理呢?請嚴格記住下面這句話:
將a和b相乘得出乘積c很容易,但要是想要經過乘積c推導出a和b極難。即對一個大數進行因式分解極難
聽不懂因式分解的童鞋先去面壁5分鐘,這麼多年數學白學了?甩給你維基百科連接,自行補課🙂:因式分解
好的,咱們繼續,非對稱加密算法就多了兩個概念——公鑰c和私鑰b。
用法以下:公鑰加密的密文只能用私鑰解密,私鑰加密的密文只能用公鑰解密。
公鑰咱們能夠隨便公開,由於別人知道了公鑰毫無用處,通過公鑰加密後的密文只能經過私鑰來解密。而想要經過公鑰推導出a和b極難。但很明顯的是,使用非對稱加密效率不如對稱加密,由於非對稱加密須要有計算兩個密鑰的過程。
咱們經過密碼學中的兩個典型的愛麗絲和鮑勃人物來解釋這個非對稱加密算法的過程:
客戶端叫作愛麗絲,服務器叫作鮑勃。
愛麗絲: 鮑勃我要給你發送一段消息,把你的公鑰給我吧;
鮑勃: OK,這是個人公鑰:234nkjdfdhjbg324**;
愛麗絲:收到公鑰,我給你發送的消息通過公鑰加密以後是這樣的:#$#$@#@!$%*(@;
鮑勃:好的,收到了,親,我來用個人私鑰解密看下你真正要給我發送的內容;
上述過程就是一個非對稱加密的過程,這個過程安全麼?好像是很安全,即便查理(通訊中的第三位參加者)截取了密文和公鑰沒有私鑰仍是無法獲得明文。😂
可若是第三者查理髮送給愛麗絲他本身的公鑰,而後愛麗絲用查理給的公鑰加密密文發送了出去,查理再經過本身的私鑰解密,這不就泄露信息了麼?咱們須要想個辦法讓愛麗絲判斷這個公鑰究竟是不是鮑勃發來的。
因而就有了數字證書的概念:
數字證書就是互聯網通信中標誌通信各方身份信息的一串數字,提供了一種在Internet上驗證通訊實體身份的方式,數字證書不是數字身份證,而是身份認證機構蓋在數字身份證上的一個章或印(或者說加在數字身份證上的一個簽名)。
😑上面官方的解釋看起來就頭大。其實它就是一段信息。
數字證書內容大致以下:
數字證書是由權威機構——CA機構統一來進行發行,咱們絕對信任這個機構,至於CA機構的安全性…反正99.99%之下都是安全的。🕵
爲了防止中間有人對證書內容進行更改,有了一個數字簽名的概念,所謂的數字簽名就是把以上全部的內容作一個Hash操做,獲得一個固定長度而後再傳給鮑勃。然而若是別人截取了這個證書而後更改內容,同時生成了新的Hash值那怎麼辦?處於這個考慮,CA機構在頒發這個證書的時候會用本身的私鑰將Hash值加密,從而防止了數字證書被篡改。
好,咱們來梳理下整個過程:
如上,是整個數字證書的使用過程就是這樣的。
多說一句,非對稱加密實際應用的例子除了SSL還有不少,好比SSH、電子簽名等;
如上提到的,非對稱加密計算量很大,效率不如對稱加密,咱們打開網頁最注重的是啥?是速度!是速度!是速度!🏃🏃🏃
這點SSL就玩的很巧妙了🤣,通訊雙方經過對稱加密來加密密文,而後使用非對稱加密的方式來傳遞對稱加密所使用的密鑰。這樣效率和安全就都能保證了。
先用語言來闡述下:
俗話說一圖勝前言,我畫了一個圖來講明這個過程:
OK,整個進行數據加密的過程結束。咱們再來回憶下內容:
文中闡述不妥之處還望雅正,不吝感激。
轉載請註明出處。
以上。