实战-Android应用使用tcpdump抓包工具

在Android 应用中,使用tcpdump 命令抓取系统日志

Runtime.getRuntime().exec 
("busybox timeout -t 10 /system/xbin/tcpdump -i eth0 -s 0 -w /sdcard/test.pcap -W 1")

不出意外会报如下错误:

tcpdump: eth0: You don't have permission to capture on that device

tcpdump使用raw socket,需要进程在net_raw组,android并未将net_raw与任何权限关系,需修改platform.xml将net_raw组置于android.permission.NET_ADMIN权限之下。

1.frameworks/base/data/etc/platform.xml 增加如下权限:

<permission name="android.permission.NET_ADMIN" >
        <group gid="net_admin" />
        <group gid="net_raw" />
    </permission>

2.应用的AndroidManifest.xml 中加入

<uses-permission android:name="android.permission.NET_ADMIN" />

另外,系统中如果没有tcpdump 命令,还需要将tcpdump 加入编译选项,编译到ROM中

# tcpdump
PRODUCT_PACKAGES += \
    tcpdump
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值