MikroTik’s inbuilt Hotspot allows a quick and simple way to provide Wi-Fi and internet connectivity with the control and flexibility required for public spaces such as cafés, hotels, accommodations, festivals, etc.
In this tutorial, we will look at setting up a hotspot on a single router (hAP AX2) and using the built-in user management. There are many more additional features and configurations available, but we will focus on the basics here and look at those more complex setups in other tutorials.
Hotspot Bridge and LAN
First, we create a dedicated bridge for our hotspot users.
data:image/s3,"s3://crabby-images/d39ca/d39caf5b763174cf9d4a71d631772c728deec3e7" alt=""
Then, add the interfaces that will be connected to the hotspot to that bridge. In our case, we’re creating a Wi-Fi hotspot so we’re adding both our wifi1 &2 interfaces.
data:image/s3,"s3://crabby-images/8fff9/8fff9497b5298934387e932c37043f12773ac768" alt=""
Now we need to give our bridge an IP address (IP > Address)
data:image/s3,"s3://crabby-images/d2e79/d2e79932979aa976827ef82f2dd7a32ddf647e90" alt=""
SSL Certificate (optional)
Now, this part is optional and has a few caveats. Firstly, your MikroTik needs to be publicly internet facing so not CGNAT or 4G/5G (basically where your device doesn’t receive a public routable IP address). If it does, however sit behind another router, then you can port forward ports 80 and 443.
The second part is that you will need your own public domain name, i.e mikrotikmasters.com, or you can use MikroTik’s built-in DDNS (IP > Cloud) and use the DDNS Name. In my example, I will generate and install a public SSL cert from Let’s Encrypt using a subdomain I added to my main domain: hotspot.mikrotikmasters.com.
This all means that when the clients connect to the hotspot, the data over the login screen will not only be encrypted (rather than using unencrypted HTTP/80) but will mean the user won’t see a certificate warning error, which can be a red flag for users, especially in public venues. When we download the certificate, it will verify that the IP resolved by the domain name matches, hence the need for public facing HTTP&HTTPS. We can then use that same domain and cert inside our network.
Firstly, add the relevant firewall filter rules on the input chain to allow 443 and 80 (TCP) and set the Action to accept.
data:image/s3,"s3://crabby-images/b0f3c/b0f3c16dc72bd7cee9dcebf4ab3719d25a293367" alt=""
Now open a terminal and type
/certificate enable-ssl-certificate dns-name=<your dns name>
data:image/s3,"s3://crabby-images/11ade/11ade072e49cb3e1734cd31dee15929a19b62f60" alt=""
Then once successful you will see it in your certificate menu (System > Certificates)
data:image/s3,"s3://crabby-images/7a36d/7a36df3775697f9424d4491b4f2d56c3a2bb1436" alt=""
To test, open up IP > Services and enable www-ssl and the certificate should already be selected. Then load the domain in your browser and you should see Webfig login with a valid cert.
data:image/s3,"s3://crabby-images/6a3d9/6a3d9c7fac424bc58699ccec7d948109ad8faeeb" alt=""
data:image/s3,"s3://crabby-images/f1342/f1342f7b495f8d79bdeb8c850ab32b44edd8fadb" alt=""
Hotspot Setup
Hotspot Setup Wizard
Now open up IP > Hotspot and click Hotspot Setup
data:image/s3,"s3://crabby-images/2c77f/2c77f773b438572b4b4236979c04052dc05e1969" alt=""
Then follow the setup and use the following options:
HotSpot Interface | hotspot_bridge | Bridge created for the HotSpot |
Local Address of the Network | 192.168.0.1/24 | IP address of the HotSpot Bridge |
Address Pool of Network: | 192.168.0.2-192.168.0.254 | Adjust to suitable scope |
Select Certificate: | hotpspot.mikrotikmasters.com | The Let’s Encrypt SSL cert |
IP Address of SMTP Server: | 0.0.0.0 | Leave Default |
DNS Servers: | 192.168.0.1 | Use the MT as the DNS server |
DNS Name: | hotpspot.mikrotikmasters.com | Match the cert name |
Name of Local Hotspot User: | admin / <test password> | Use something more secure |
data:image/s3,"s3://crabby-images/75781/7578105d02bfe2b51c04c38cea8f87e7aa876500" alt=""
Configured Server:
data:image/s3,"s3://crabby-images/07b91/07b91e86472314f36f205ed541c38d999a9e7a05" alt=""
Under Server Profiles, on the newly generated profile, under Login uncheck Cookie
data:image/s3,"s3://crabby-images/e2710/e27109766e50feb2f6afdc3dca965ae8d21c4b66" alt=""
data:image/s3,"s3://crabby-images/d1fd5/d1fd5058f6eba01c01985265f01a0ada3511548e" alt=""
Additional Users
To add new users, go to Hotspot > Users and select the hotspot1 server and set a username & password.
data:image/s3,"s3://crabby-images/593d8/593d8a13ba25822986f8740f62f891649a398a77" alt=""
Connecting/Testing
We have completed the minimal setup to use our MikroTik Hotspot. We can now view the SSID in our available connections and connect to it. If the Login screen doesn’t appear, it will prompt us to sign in.
We can use those credentials we created during the hotspot setup wizard (admin / admin) or add a new user as shown above.
data:image/s3,"s3://crabby-images/b268f/b268fd02c68d40b0f29f12b72aa2a6a1a8dd91bb" alt=""
data:image/s3,"s3://crabby-images/c7c27/c7c27c1b91253a9fa458e683d503fe36ba901182" alt=""