android 通过tcpdump抓包

这篇博客详细介绍了如何在Android设备上进行tcpdump抓包操作,包括获取root权限,下载tcpdump,通过ADB推送文件,使用命令行执行tcpdump抓包,以及将pcap文件拉取到电脑进行分析。同时,还提到了在某些设备上由于权限问题如何通过ADB执行su命令切换到root用户来运行tcpdump。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.手机root权限

2.下载tcpdump  

http://www.strazzere.com/android/tcpdump

3. adb push E:\tcpdump  /data/local/tcpdump

4.adb shell  用su获得root权限

5. cd /data/local

6. tcp -i any -p -s 0 -w /sdcard/capture.pcap

参数:-i  监听任何网络接口

-p :禁用混杂模式(不工作)

-s 0 :对整个包截图

-w :把结果写入文件。(而不是打印)

。。。。做其它想要的截图,ctrl +C 停止。

7.把文件pull 出来  

adb pull /sdcard/capture.pcap d:/

8.在电脑上用wireshark打开capture.prcap分析log

如果想看到执行文件而不是截图结果,执行下面命令

 adb shell tcpdump -n -s 0 

一些典型的例子:

1.监听http

adb shell tcpdump -X  -n -s 0 port 8080

据以上的信息,写一个bat去执行(tcpdump文件必须在当前目录里)。

 

开始tcpdump 

adb push tcpdump /data/local/tcpdump
adb shell chmod 6755 /data/local/tcpdump
adb shell rm -r /sdcard/capture.pcap
adb shell  /data/local/tcpdump -i any -p -s 0 -w /sdcard/capture.pcap
pause
 

下载tcpdump文件到电脑 

 adb pull /sdcard/capture.pcap capture.pcap 

 

 问题:有些机器root后通过adb shell 后,默认不是root用户,需要输入 su才能切换到root,这样在执行批处理会有问题,解决方法如下

adb shell "su -c 'sleep 1'"
adb start-server

adb push tcpdump /data/local/tcpdump 

 

 因没有root权限导致的问题

adb shell su -c "/data/local/tmp/tcpdump -i any -p -s 0 -w /sdcard/netCapture.pcap"




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值