使用wireshark工具抓取手機包

從網絡上面搜索到的資料看,要抓取手機中app的網絡包有下面幾種方式:windows

(1).將tcpdump移植到Android平臺,而後在命令行下啓動tcpdump進行抓包。Tcpdump程序實際上能夠看做是wireshark的命令行版本,將該程序移植到Android平臺直接抓包,這是一種最直接的抓包方式,而後將抓獲的數據包文件,從手機傳到windows系統上用wireshark打開進行分析,這種方式貌似不能用於蘋果手機。瀏覽器

(2).使用fiddler,在windows系統上打開fiddler軟件,該軟件會將咱們的電腦變成一個代理,而後在手機上設置wifi網絡,將代理指定爲開啓fiddler的那臺電腦,而且端口設置爲fiddler偵聽的8888端口,這時候使用手機訪問的數據,就會經過該代理,在fiddler中就能夠看到http的數據包。這種方法我試了半天怎麼都看不到數據包,不知道哪裏出問題了,根據原理,這種方式支持能夠經過代理訪問網絡的手機。因此從原理上說是支持Android和蘋果手機的。網絡

(3).經過各類方式在pc電腦上創建wifi熱點,而後使用wireshark在pc電腦上監視該wifi熱點,經過手機鏈接該熱點訪問網絡。這樣wireshark會獲取全部流經該熱點的數據包這種方式適用於全部可以無線訪問的手機,也就是說全部的Android和蘋果手機。app

那麼如何在pc電腦上創建wifi熱點呢,有這麼幾種辦法:iphone

(1).Win7電腦通過設置,能夠將無線網卡設置爲wifi熱點,這種方法我之前用過,能夠成功,可是步驟繁瑣,並且不必定可以成功,其餘的windows系統估計就沒戲了。tcp

(2).使用軟件自動創建wifi熱點,不須要本身手工配置,這樣的軟件有Connectify Hotspot,獵豹免費wifi,360免費wifi軟件,這幾個軟件我都使用過,比較好用,這種方式一樣也只能針對有無線網卡的筆記本電腦,原理也是將筆記本電腦上的無線網卡創建熱點了,只不過是軟件自動的,不須要人工設置,比方法1要方便。命令行

注意:通過實驗發現,手機鏈接這種方式創建的熱點,所發送的數據,用wireshark去抓包,須要捕獲電腦上自己聯網的那個「網絡鏈接」,例如個人筆記本上面有一個「本地鏈接」,該鏈接是使用有線網絡的。我用獵豹免費wifi軟件創建一個熱點以後,個人電腦上多出一個「無線網絡鏈接3」,能夠看到該「無線網絡鏈接3」是獵豹生成的,可是我抓包的時候,wireshark須要捕獲「本地鏈接」上的包,也就是個人手機訪問的數據實際上仍是使用的「本地鏈接」,通訊IP也是「本地鏈接」上的IP地址,而在手機的wifi鏈接設置中看到的ip地址,在我抓的包中也搜不到,也就是說手機經過該熱點訪問網絡,實際上仍是使用的「本地鏈接」的IP地址,至因而什麼原理,我目前也不太清楚。可是下面要說的隨身wifi硬件則與此不一樣,隨身wifi是創建了網卡。代理

(3).使用隨身wifi硬件。這種也是很方便的方法,並且比較穩定,對筆記本電腦和臺式機均可以使用。我以前買了一個360的隨身wifi(不是打廣告,本人對360公司不感冒,可是他的隨身wifi作的確實還能夠,同事中有買小米wifi的,不太穩定)。只要在360的官網上下載驅動,直接插上隨身wifi就可使用,我推薦使用這種方法。調試

若是你用的是筆記本電腦可使用方法2,若是是臺式機器可使用方法3。blog

下面重點說明,經過隨身wifi創建熱點,而後使用wireshark抓包的辦法,其餘方式創建熱點抓包的原理同樣,只不過是創建熱點的方式不一樣而已,抓包過程沒有區別:

首先插入隨身wifi:

使用手機鏈接上面的wifi,而後打開「網絡和共享中心」,在裏面點擊咱們使用隨身wifi創建的網絡鏈接:

1

1

裏面能夠看到該連接的網卡物理地址,以及ipv6的地址信息,這應該是隨身wifi創建的一個網卡,之因此要查看這些信息,是由於咱們要肯定wireshark抓包的時候抓取那個網卡的信息,通常電腦上有多網卡或者是有虛擬機可能也會生成虛擬網卡。

打開wireshark,選擇菜單「Capture」—「Interface」在彈出的對話框中有一列是IP欄,能夠看到除了本機的網絡鏈接之外,好像其餘的網絡連接這一欄顯示的都是IPv6的地址,其中咱們能夠找到與上面網絡鏈接信息中匹配的IP地址:

1

還能夠點擊該條目右邊的「Details」按鈕,打開詳細信息對話框,在「802.3(Ethernet)」選項卡中,能夠看到網卡的物理地址,該物理地址與上面的網絡鏈接對話框中顯示的物理地址是對應的:

1

這樣能夠肯定咱們須要抓取哪一個網卡的數據,肯定以後,直接點擊該條目的「Start」按鈕,使用連上該wifi的手機隨便訪問網絡,就能夠抓取全部包了,若是嫌查看網卡信息麻煩,你能夠把這幾個顯示有數據包的網卡都抓包試一下,就應該能夠看出來隨身wifi對應的是那個網絡鏈接了。

在手機上查看鏈接該wifi被分配的IP地址信息:

1

在wireshark的抓包結果中,經過地址與http協議過濾出該地址172.24.160.3相關的數據包獲得以下的結果:

1

這些數據是我在小米手機上,經過UC瀏覽器瀏覽博格園電腦版網頁抓獲的全部數據包。

對於iphone手機的抓包過程沒有任何區別。該方法能夠抓獲全部發送自手機的數據包,包括http與非http的全部數據包。

我的認爲這種方式很是簡單方便,抓取的數據包全面,並且經過隨身wifi設置熱點不須要任何繁瑣的配置,僅僅是安裝一個驅動而已,實際上隨身wifi好像是新建了一個網卡。咱們只要用wireshark抓獲該隨身wifi創建的網卡的數據就能夠了。對於從事app開發的園友來講19塊錢買一個wifi是很是值得的,這會爲你的調試,以及研究別人的協議提供很是大的幫助

相關文章
相關標籤/搜索