通过adb shell使用iptables命令进行Android网络转发

前言
最近接到一个任务:对Android平台RK3399的板子进行WIFI到Ethernet的网络转发,首先想到的最直接、最简单的方法就是通过其内核自带的iptables在命令行中实现。这是我第一次上传博文,由此记录我之前的调试经验,为了以后遗忘的时候可以再次回顾,有不妥的地方还有劳各位朋友纠正。

步骤
1、首先通过windows进入adb shell
按下微软图标+R,输出cmd进入windows命令行。在adb shell中使用iptabls命令之前需要的获取系统root权限,通过adb root,再adb shell即可,或者在adb shell后直接su获取权限,前提是你的板子或者手机root过,当进入shell名字后为一#表明是root用户。

2、查看当前filter和nat预设表中的规则
iptables -t filter/nat -L -n -v

3、清除当前filter和nat预设表中的规则
iptables -t filter/nat -F

4、添加ip rule和ip route
ip route ip route add default via 192.168.100.1 dev wlan0
ip rule add from all lookup local/main/default

5、在nat表中添加从Ethernet网卡进入然后从WIFI网卡出去的规则
iptables -t nat -A POSTROUTING -o wlan0 -s 192.168.10.0/24 -j MASQUERADE

6、配置Ethernet网卡的ip地址和子网掩码
ifconfig eth0 192.168.10.1 netmask 255.255.255.0

7、开启内核网络转发
echo 1 > /proc/sys/net/ipv4/ip_forward

你可能感兴趣的:(通过adb shell使用iptables命令进行Android网络转发)