Skip to content

Latest commit

 

History

History
265 lines (209 loc) · 4.13 KB

Monitor_Mode - Realtek.md

File metadata and controls

265 lines (209 loc) · 4.13 KB

Monitor Mode Testing for...

https://github.com/morrownr/8812au-20210629
https://github.com/morrownr/8821au-20210708

Notes:

"$ sudo iw dev" does not display channel and txpower information correctly. This appears to be a cosmetic problem.

For Debian based Linux Distros such as:

Kali Linux
Raspberry Pi OS
Linux Mint
Ubuntu

Update system

sudo apt update
sudo apt full-upgrade

Ensure WiFi radio is not blocked

sudo rfkill unblock wlan

Install the aircrack-ng package

sudo apt install aircrack-ng

Check wifi interface information

iw dev

Information

The wifi interface name wlan0 is used in this document but you will need to substitute the name of your wifi interface while using this document.


Disable interfering processes

Option 1, recommended for Kali and Raspberry Pi OS.

sudo airmon-ng check kill

Option 2, another way that works for me on Linux Mint and Ubuntu:

Note: I use multiple wifi adapters in my system and I need to stay connected to the internet while testing. This option works well for me and allows me to stay connected by allowing Network Manager to continue managing wlan1 while wlan0 is used for monitor mode.

Ensure Network Manager doesn't cause problems

sudo nano /etc/NetworkManager/NetworkManager.conf

add

[keyfile]
unmanaged-devices=interface-name:wlan0mon;interface-name:mon0

Note: The above tells Network Manager to leave the wlan0mon and mon0 interfaces alone. The examples below will use wlan0mon.

sudo reboot

Change to monitor mode

Note: I have provided a script called to start-mon.sh to automate this process.

Option 1.

sudo airmon-ng start <wlan0>

Option 2.

Check the wifi interface name and mode

iw dev

Take the interface down

sudo ip link set <wlan0> down

Rename the interface to wlan0mon

sudo ip link set <wlan0> name wlan0mon

Set monitor mode

sudo iw wlan0mon set monitor control

Bring the interface up

sudo ip link set wlan0mon up

Verify the mode has changed

iw dev

Test injection

Option for 5 GHz and 2.4 GHz

sudo airodump-ng wlan0mon --band ag

Option for 5 GHz only

sudo airodump-ng wlan0mon --band a

Option for 2.4 GHz only

sudo airodump-ng wlan0mon --band g

Set the channel of your choice

sudo iw dev wlan0mon set channel <channel> [NOHT|HT20]
sudo aireplay-ng --test wlan0mon

Test deauth

Option for 5 GHz and 2.4 GHz

sudo airodump-ng wlan0mon --band ag

Option for 5 GHz only

sudo airodump-ng wlan0mon --band a

Option for 2.4 GHz only

sudo airodump-ng wlan0mon --band g
sudo airodump-ng wlan0mon --bssid <routerMAC> --channel <channel of router>

Option for 5 GHz:

sudo aireplay-ng --deauth 0 -c <deviceMAC> -a <routerMAC> wlan0mon -D

Option for 2.4 GHz:

sudo aireplay-ng --deauth 0 -c <deviceMAC> -a <routerMAC> wlan0mon

Revert to Managed Mode

Check the wifi interface name and mode

iw dev

Take the wifi interface down

sudo ip link set wlan0mon down

Rename the wifi interface to

sudo ip link set wlan0mon name <wlan0>

Set managed mode

sudo iw <wlan0> set type managed

Bring the wifi interface up

sudo ip link set <wlan0> up

Verify the wifi interface name and mode has changed

iw dev

Change the MAC Address before entering Monitor Mode

Check the wifi interface name, MAC address and mode

iw dev

Take the wifi interface down

sudo ip link set dev <wlan0> down

Change the MAC address

sudo ip link set dev <wlan0> address <new mac address>

Rename the wifi interface to wlan0mon

sudo ip link set <wlan0> name wlan0mon

Set monitor mode

sudo iw wlan0mon set monitor control

Bring the wifi interface up

sudo ip link set dev wlan0mon up

Verify the wifi interface name, MAC address and mode has changed

iw dev

Change txpower

sudo ip link set wlan0mon down
sudo iw dev wlan0mon set txpower fixed 1600 (1600 = 16 dBm)
sudo ip link set wlan0mon up