Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發實例 >> Android 聯網監控抓包工具的制作(tcpdump的使用)

Android 聯網監控抓包工具的制作(tcpdump的使用)

編輯:Android開發實例

最近做一個Android聯網抓包的工具

自己在網上搜索了好久

發現還是沒有頭緒

於是考慮在linux層上下功夫

於是采用linux的tcpdump來實現了抓包的功能

用簡單的話來定義tcpdump,就是:dump the traffic on a network,根據使用者的定義對網絡上的數據包進行截獲的包分析工具。

  作為互聯網上經典的的系統管理員必備工具,tcpdump以其強大的功能,靈活的截取策略,成為每個高級的系統管理員分析網絡,排查問題等所必備的東東之一。

對於tcpdump詳細的可以參考http://baike.baidu.com/view/76504.htm?fr=ala0_1_1百度百科的介紹

我這裡主要介紹一下如何在Android上使用tcpdump

我所采用的測試機是破解版G2和模擬器

具體的就是在APK程序裡執行linux命令

  1. tcpdump -p -vv -s 0 -w /sdcard/capture.pcap 

 

這樣就能夠將抓到的包在sdcard上寫一個capture.pcap文件

而這個文件可以用wireshark在PC上打開進行查看 非常方便

具體的源代碼如下

MainHook.java

  1. package zy.hook;  
  2. import java.io.IOException;  
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.util.Log;  
  6. public class MainHook extends Activity {  
  7.     /** Called when the activity is first created. */ 
  8.     @Override 
  9.     public void onCreate(Bundle savedInstanceState) {  
  10.         super.onCreate(savedInstanceState);  
  11.         setContentView(R.layout.main);  
  12.         try {  
  13.             //Runtime.getRuntime().exec("su");  
  14.             //Runtime.getRuntime().exec("dd if=/sdcard/tcpdump of=/data/local/tcpdump");  
  15.             //Runtime.getRuntime().exec("chmod 6755 /data/local/tcpdump");  
  16.             Runtime.getRuntime().exec("tcpdump -p -vv -s 0 -w /sdcard/capture.pcap");  
  17.             Log.i("run","success!!!!!!!!!");  
  18.         } catch (IOException e) {  
  19.             // TODO Auto-generated catch block  
  20.             e.printStackTrace();  
  21.             Log.i("run",e.toString());  
  22.         }  
  23.     }  

 

AndroidManifest.xml

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android" 
  3.       package="zy.hook" 
  4.       android:versionCode="1" 
  5.       android:versionName="1.0"> 
  6.     <application android:icon="@drawable/icon" android:label="@string/app_name"> 
  7.         <activity android:name=".MainHook" 
  8.                   android:label="@string/app_name"> 
  9.             <intent-filter> 
  10.                 <action android:name="android.intent.action.MAIN" /> 
  11.                 <category android:name="android.intent.category.LAUNCHER" /> 
  12.             </intent-filter> 
  13.         </activity> 
  14.     </application> 
  15.     <uses-sdk android:minSdkVersion="7" /> 
  16.    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 
  17. </manifest>  

 

尤其不要忘記了權限<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

的聲明

運行程序我們就可以抓包了

會在sdcard上生成capture.pcap文件

抓一段時間之後,將文件從sdcard上導出

然後我們用wireshark打開

可以非常方便的查看我們抓到的包

希望能夠對大家有用

轉自:http://blog.csdn.net/Zengyangtech/archive/2010/08/31/5853366.aspx

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved