This is a fork of dchristl's ESP32 NAT Router Extended but with NextDNS feature.
Based on martin-ger's ESP32 NAT Router-project
- Extend range of WiFi network (Repeater)
- Additional network for guests
- Portable usage with a small, low power device (battery powered)
- Bypass restrictions in public WiFis, like device and rate limit
- Scanning for APs (s. limitations)
- User friendly UI with mobile support
- Resetting the device in UI and with Pin/Button
- OTA-Updates
- Keep connection alive on networks with forced disconnect
- Secure frontend by password or complete disabling
- Show connected state and quality in UI
- Disable the on board indicator LED
- NextDNS Support with automatic linking IP to your NextDNS account, see here
After first boot the ESP32 NAT Router will offer a WiFi network with an open AP and the ssid "ESP32_NAT_Router". Configuration can either be done via a simple web interface or via the serial console.
The web interface allows for the configuration of all parameters. Connect you PC or smartphone to the WiFi SSID "ESP32_NAT_Router" and point your browser to "http://192.168.4.1". This page should appear:
First enter the appropriate values for the uplink WiFi network, the "STA Settings". Leave password blank for open networks. Click "Connect". The ESP32 reboots and will connect to your WiFi router.
Now you can reconnect and reload the page and change the "Soft AP Settings". Click "Set" and again the ESP32 reboots. Now it is ready for forwarding traffic over the newly configured Soft AP. Be aware that these changes also affect the config interface, i.e. to do further configuration, connect to the ESP32 through one of the newly configured WiFi networks.
- Download latest release
- Download esp32nat_extended_full_vX.X.X.zip for fresh install
- Download esp32nat_extended_update_vX.X.X.zip for update
- Install esptool
If your device was used before for other projects or you want to reset all setting from previous version. Complete data loss! Unpack archive first and then execute:
esptool.py write_flash 0x0 esp32nat_extended_full_vX.X.X.bin
If this project was already installed. No data loss from previous version. The preferred way is with OTA-Updates. If you want to do it manually:
esptool.py write_flash 0x10000 esp32nat_extended_vX.X.X.bin
If any problem occurs, erase flash manually before flashing the full version :
esptool.py erase_flash
As an alternative you might use Espressif's Flash Download Tools.
Check the marked parameters and files like below (ckeck the COM-Port for your environment).
Check the addresses like below:
see How to setup environment and build
Due to technical limitations, a client cannot be simultaneously connected to the device and scan for Wi-Fi networks. Before the scan starts, all the clients will be disconnected. After that, the scan will be saved in NVS,and the device will reboot. Upon reconnecting to the device, you will be able to view the scanned networks.
An automatic redirect occurs the first time. Afterward, the scanned networks can be viewed three more times before they are deleted from the NVS to save storage space.
If you have any problems, suggestions for new features feel free to ask or raise an issue. This is a spare time project, I will answer if I'm free. If you like my work and want to support me, you can buy me coffee or send me a donation via PayPal
see Advanced topics