WireShark如何破解SSL加密網(wǎng)絡數(shù)據(jù)包
WireShark如何破解SSL加密網(wǎng)絡數(shù)據(jù)包
一般來說,我們用WireShark來抓取包進行分析是沒有多大問題的,但碰到的是用SSL/TLS等加密手段加密過的網(wǎng)絡數(shù)據(jù)的時候,往往我們只能束手無策。請看下面學習啦小編整理的解決方法!
WireShark破解SSL加密網(wǎng)絡數(shù)據(jù)包的方法
相信能訪問到這篇文章的同行基本上都會用過流行的網(wǎng)絡抓包工具WireShark,用它來抓取相應的網(wǎng)絡數(shù)據(jù)包來進行問題分析或者其他你懂的之類的事情。一般來說,我們用WireShark來抓取包進行分析是沒有多大問題的。但這里有個問題是,如果你碰到的是用SSL/TLS等加密手段加密過的網(wǎng)絡數(shù)據(jù)的時候,往往我們只能束手無策。在過去的話,如果我們擁有的該傳輸會話的私鑰的話我們還是可以將它提供給WireShark來讓其對這些加密數(shù)據(jù)包進行解密的,但這已經(jīng)是想當年還用RSA進行網(wǎng)絡數(shù)據(jù)加密的年代的事情了。當今大家都已經(jīng)逐漸擁抱前向加密技術PFS 的時代了,所以該方法就不再適用了。因為前向加密技術的目的就是讓每個數(shù)據(jù)交互都使用的是不同的私鑰,所以你像以前RSA時代一樣想只用一個私鑰就能把整個session會話的網(wǎng)絡數(shù)據(jù)包都破解出來的話是不可能的了。所以這將是一個挺惱火的事情。
大家先別火起,這里我來告訴你另外一個簡單的方法來解決這個問題!其實Firefox和Chrome瀏覽器都支持用日記文件的方式記錄下用來加密TLS數(shù)據(jù)包對稱會話秘鑰的。這樣你就可以在WireShark中指定該文件來快速完成你的破解目的了。請繼續(xù)往下看具體的步驟。首先你需要配置一個環(huán)境變量。
3.1 在Windows下的配置:
怎么去到環(huán)境變量配置頁面相信不需要我多說了,畢竟國內還是Windows的天下。
在上圖的位置增加一個新的叫做“SSLKEYLOGFILE”的環(huán)境變量并指定其路徑到你想要保存你的會話私鑰的地方。
3.2 在Linux或者MAC OS X上的配置:
$ export SSLKEYLOGFILE=~/path/to/sslkeylog.log
當然,如果你想在你的系統(tǒng)每次啟動的時候都指定該日記路徑的話,你可以在你的Linux下執(zhí)行下面的動作:
~/.bashrc
或者在你的MAC OS X上執(zhí)行以下命令:
~/.MacOSX/environment
這樣我們下次啟動Firefox或者Chrome的開發(fā)者模式的時候,TLS秘鑰就會自動寫入到該指定文件下面了。為了支持這個功能,你當前的WireShark版本必須是1.6或者更新。我們僅僅要做的就是先進入偏好設置頁面:
展開協(xié)議選項:
找到SSL選項然后如下圖所示打開上面設置好的會話秘鑰保存文件:
下圖就是我們通常見到的WireShark抓到TLS數(shù)據(jù)包后的顯示結果:
This is what it looks like when you switch to the “Decrypted SSL Data” tab. Note that we can now see the request information in plain-text! Success!大家可以看到WireShark下面會有一個“已解密的SSL Data”的標簽,點擊之后你就可以如下圖所示的看到已經(jīng)解密的TLS數(shù)據(jù)包的相信信息了:
通過本文我真心希望你能從中學到一些東西,該方法讓我們能夠如此直截了當?shù)娜グ裈LS數(shù)據(jù)包給破解出來。這種方式的另外一個值得一提的好處是,給會話過程中的兩臺機器根本不需要安裝任何Wireshark工具,因為你會擔心安裝上去會搞得問題是做多錯多都不知道哪里出問題了。你只需要做的是把他們上面的該會話秘鑰文件指定到一個網(wǎng)絡共享文件夾然后用另外一個已經(jīng)機器上安裝WireShark并如前所示指定該秘鑰文件進行抓包就了事了。
看了“WireShark如何破解SSL加密網(wǎng)絡數(shù)據(jù)包”的人還看了