5

Мой ноутбук (использующий Ubuntu 13.10) подключен к Интернету по проводному соединению в eth0 с ip 192.168.42.13 а также работает как wifi hotspot на wlan0 с ip 192.168.1.1 (я использовал airbase -ng для настройки точки доступа ) , Теперь у меня есть Android-устройство, которое необходимо подключиться к этому Wi-Fi. Я вижу, что мой андроид может подключиться к hotspot и получить следующие настройки сети с сервера dhcp я настроил. (Я использовал инструмент Net Info II из PlayStore, чтобы увидеть подробности ниже на моем Android).

# My android network settings (connected to the wlan0 of my laptop):
ip address: 192.168.1.10
subnetmask: 255.255.255.0
gateway   : 192.168.1.254
ap-mac    : xx:xx:xx:xx:xx:xx

# My pc's eth0 configuration
ip address: 192.168.42.13
submetmask: 255.255.255.0
gateway   : 192.168.42.129
iface mac : yy:yy:yy:yy:yy:yy

# My pc's wlan0 (hotspot interface) configuration
ip address: 192.168.1.1
subnetmask: 255.255.255.0
gateway   : 192.168.1.1
iface mac : zz:zz:zz:zz:zz:zz

Эта нить здесь говорит о подобной проблеме. Я вижу, что мне нужно пересылать пакеты между eth0 и сетью wlan0 чтобы подключить устройства моей беспроводной точки доступа к Интернету. Теперь, как мне переслать пакеты, которые я получаю от wlan0 to eth0 и eth0 to wlan0 чтобы подключить мое устройство к интернету?

1 ответ1

5

Сначала вам нужно включить переадресацию IP в вашей системе. Чтобы сделать это только один раз, используйте

sysctl -w net.ipv4.ip_forward=1

или же

echo 1 > /proc/sys/net/ipv4/ip_forward

как корень. Если вы хотите сделать его постоянным, отредактируйте

/etc/sysctl.conf

и добавьте строку, содержащую

net.ipv4.ip_forward = 1

Это будет применяться при перезагрузке или при запуске

sysctl -p /etc/sysctl.conf

Как только это будет сделано, вам, вероятно, понадобятся соединения NAT, поскольку маловероятно, что ваш маршрутизатор знает, что сеть 192.168.1.0/24 доступна через 192.168.42.13. Если 192.168.42.13 является статическим, вы можете использовать

iptables -t nat -A POSTROUTING -i wlan0 -s 192.168.1.0/24 -j SNAT --to-source 192.168.42.13

иначе использовать

iptables -t nat -A POSTROUTING -i wlan0 -s 192.168.1.0/24 -j MASQUERADE

Проверьте Ubuntu IptablesHowTo, как сохранить эти правила при перезагрузке.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .