Android 联网监控抓包工具的制作(tcpdump的使用)
来源:互联网 发布:女神联盟兽铠精炼数据 编辑:程序博客网 时间:2024/05/12 04:18
最近做一个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命令
- tcpdump -p -vv -s 0 -w /sdcard/capture.pcap
这样就能够将抓到的包在sdcard上写一个capture.pcap文件
而这个文件可以用wireshark在PC上打开进行查看 非常方便
具体的源代码如下
MainHook.java
- package zy.hook;
- import java.io.IOException;
- import android.app.Activity;
- import android.os.Bundle;
- import android.util.Log;
- public class MainHook extends Activity {
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- try {
- //Runtime.getRuntime().exec("su");
- //Runtime.getRuntime().exec("dd if=/sdcard/tcpdump of=/data/local/tcpdump");
- //Runtime.getRuntime().exec("chmod 6755 /data/local/tcpdump");
- Runtime.getRuntime().exec("tcpdump -p -vv -s 0 -w /sdcard/capture.pcap");
- Log.i("run","success!!!!!!!!!");
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- Log.i("run",e.toString());
- }
- }
- }
AndroidManifest.xml
- <?xml version="1.0" encoding="utf-8"?>
- <manifest xmlns:android="http://schemas.android.com/apk/res/android"
- package="zy.hook"
- android:versionCode="1"
- android:versionName="1.0">
- <application android:icon="@drawable/icon" android:label="@string/app_name">
- <activity android:name=".MainHook"
- android:label="@string/app_name">
- <intent-filter>
- <action android:name="android.intent.action.MAIN" />
- <category android:name="android.intent.category.LAUNCHER" />
- </intent-filter>
- </activity>
- </application>
- <uses-sdk android:minSdkVersion="7" />
- <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
- </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
- Android 联网监控抓包工具的制作(tcpdump的使用)
- Android 联网监控抓包工具的制作(tcpdump的使用)
- Android 联网监控抓包工具的制作(tcpdump的使用)
- Android 联网监控抓包工具的制作(tcpdump的使用)
- Android 联网监控抓包工具的制作(tcpdump的使用)
- Android 联网监控抓包工具的制作(tcpdump的使用)
- Android 联网监控抓包工具的制作(tcpdump的使用)
- Android的网络抓包工具Tcpdump
- Linux 抓包工具tcpdump的使用
- linux抓包工具tcpdump的使用
- tcpdump抓包工具的使用
- Android抓包工具tcpdump使用教程
- Android 下使用tcpdump 抓包工具
- Linux下抓包工具tcpdump的使用
- linux下tcpdump抓包工具的安装和使用
- linux下的抓包工具tcpdump
- linux下的抓包工具tcpdump
- Ubuntu下的抓包工具tcpdump
- ucos ii学习笔记1——任务中断和调度
- robotium自动化测试简介
- 面向对象基础知识(2)- 构造方法
- Asset file how to
- Python之分片操作
- Android 联网监控抓包工具的制作(tcpdump的使用)
- 如何让Android屏幕只能上下翻转
- [深入浅出Cocoa]iOS网络编程之Socket
- webview 不能全屏 底部 有空白部
- Linq操作集合数组
- 搭建eclipse android开发环境的一点记录
- UI组件设计:结构中定义全部的流程驱动逻辑;皮肤中完全没有流程驱动逻辑
- [深入浅出Cocoa]iOS网络编程之CFNetwork
- POJ1459--Power Network(最大流)