airkick
C implementation of the classic WLAN deauthentication attack.
The Hell Is This??
This is a commandline tool that can perform the infamous wifi deauthentication attack. Currently there are three modes of operation:
- Discovery of active wifi sessions in the vicinity.
- Deauthentication/Disassociation of a single client.
- DoS-style mass deauthentication/disassociation of all discovered sessions.
The program uses the standard pcap routines to read packets from a capture interface and write forged ones to the wire. Mode 1 implements a minimal parser with the purpose of identifying potential targets. Mode 3 builds on mode 1 by additionally dispatching frame injection threads for every connection discovered.
As of version 1.2, the parsing routines also use a copy of the IEEE Registry to automatically identify card vendors by their OUIs.
Prerequisites
This program was designed for Linux platforms, other operating systems are not supported.
Hardware requirements
Your wireless card should support capturing packets in promiscuous mode as well as packet injection, ideally at the same time. Otherwise errors are likely to occur.
Library Dependencies
- iwlib from wireless tools (for scanning).
- libpcap (packet capture and injection).
- libmnl (used for scan-ap).
Additionally, the parallelism of mode 3 is implemented via Posix Threads. So make sure an implementation of the pthreads API is present.
Installation
Quickstart
Go to the Release page and locate the latest version.
Building From Source
This project is built with the *shivers* autotools. Download the sources from
the Release page and cd
into the unpacked directory. Then initialize, configure and make:
autoreconf -i
./configure
make
Usage
The program is meant to be run from the commandline. You will most likely need elevated privileges in order to create and perform I/O operations on the pcap pseudo-interfaces. You can toggle between the different modes by supplying the appropriate parameter:
-m
Monitoring active sessions that are close by. Command format:
airkick -m -i <myNIC> [ -c max_connections ] [ -p ]
The program will first perform a scan (via iwlib) to get a list of the local access points. It will then watch for data frames sent to the APs and print the source mac addresses to the console. (Note: This means the detection of "active" connections is not foolproof. Expanding the scope to include data frames sent by the access points might provide a more complete picture of the network. Something for a future release, perhaps...)
-d
Deauthentication of a single client device. Command format:
airkick -d -i <myNIC> -s <spoofed client mac> -b <bssid> [ -a ]
This mode can be used to target a single machine whose mac address is already known.
<spoofed client mac>
should be a string of the form XX:XX:XX:XX:XX:XX
. Likewise, <bssid>
is supposed to be the mac address of the access point (in the same format).
-f
Automatic deauthentication of all discovered sessions. Command format:
airkick -f -i <myNIC> [ -c max_connections ] [ -p ] [ -a ]
This mode acts as an extension of the watch functionality. Instead of just monitoring data frames, the program will actively block clients at first sight.
Warning: This mode is anything but subtle. Unless the local network admins are on vacation (and have taken the entire IDS with them) there's no way that sudden deauthentication flood will pass unnoticed.
Options
Required
-i <myNIC>
: This parameter is mandatory for all three modes and determines which wireless card to use. myNIC should be the device name as it appears in ifconfig/ip, e.g.wlan0
.
Optional
-
-p
: If this parameter is supplied, iwlib will conduct a passive scan. The passive scan has the advantage of being "listen only", so no probe requests are sent to APs. Thus the mac address of the attacking machine should not show up in any log files. However, scan results will likely be less comprehensive than with the active counterpart.By default, an active scan is performed.
-
-c max_connections
: When using mode 1 or 3, airkick limits itself to a conservative default (tweakable at compile time) of tracked connections. This parameter can be used to increase the tracking limit. Beware, though, that the impact of doing so might be significant, especially in flood mode (every thread gets its own packet buffer and pcap handle). Use this option at your own risk. -
-a
: When blocking clients, airkick defaults to deauthentication frames. This option can be used to switch to disassociation frames should the need arise.
Screenshots
Finding active connections |
---|
Cleansing the air |
---|
Limitations
-
airkick is by no means a complete wireless suite. If you need complete wireless auditing functionality, a tool like aircrack-ng will serve you far better than this steaming pile of code.
-
It might be possible to build this tool on BSD systems, but no testing has been done so far.
-
With the (not so) recent updates to the IEEE 802.11 standard and WPA3 on the horizon airkick might already be obsolete. Of course, protocol updates always carry with them a chance of new loopholes (which translates to feature extensions for projects like this). Still, the wifi landscape is ever changing and in its current shape this little toy might soon be a relic of the "good old days".
Authors
Van Ziegelstein - Creator and Maintainer
License
This project is licensed under the GPL.