KIOPTRIX- Level 1.1 (#2)
- Layout for this exercise:
data:image/s3,"s3://crabby-images/c6b61/c6b61799f109b8149e63f441056cac38565bbaa4" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Kioptrix Level 1.1 (#2)
- Kioptrix Level 1.1 (#2) can be downloaded from here:
https://www.vulnhub.com/entry/kioptrix-level-11-2,23/
data:image/s3,"s3://crabby-images/289c7/289c7cce325bd8b088bf1d565b35edc0f565aa2d" alt=""
- Once downloaded, extracted and opened with WMware:
data:image/s3,"s3://crabby-images/90f26/90f2685035ae89dd0a0f5d33225ad465f6721c64" alt=""
2 - ENUMERATION
- First, using netdiscover let's notice that the only IP address in the local network working with WMware is 192.168.1.22, so it should correspond to the vulnerable machine Kioptrix:
data:image/s3,"s3://crabby-images/30d63/30d63c5db6b2282dff9d6d0a246b2279e9a46b69" alt=""
data:image/s3,"s3://crabby-images/47d76/47d7603a6679ddacd36e7bc5a1da097ddef344e3" alt=""
- Scanning for versions and the operating system with Nmap:
data:image/s3,"s3://crabby-images/67535/6753565faefc7b7546ff251ddebc114e7f06dc50" alt=""
3 - EXPLOITATION
- Connecting from the browser's attacker the web server answers with a login page, where we can try an SQL injection:
data:image/s3,"s3://crabby-images/1c37b/1c37b22fc98545648b9c67c6742f2cf9e5b0f839" alt=""
- The injection is successful, leading to a ping application:
data:image/s3,"s3://crabby-images/0061b/0061bc789efecf0f594aa82746883e2655a4ba6f" alt=""
- Pinging to the attacker's IP:
data:image/s3,"s3://crabby-images/ad874/ad874962ff6b0bbbfc924b16f644a543b81ed7b2" alt=""
data:image/s3,"s3://crabby-images/2b6c1/2b6c17ea15c142d5cda007ef84d21fcf8b64e035" alt=""
- Trying a Command Injection, it is also successful:
data:image/s3,"s3://crabby-images/31161/31161977cb17c427ff6f3d35a435b673abc1682d" alt=""
data:image/s3,"s3://crabby-images/03792/03792724224e4b35fa66453a23aedc4205d00ce1" alt=""
- Setting a listener session with netcat at the attacker's side:
data:image/s3,"s3://crabby-images/2cacf/2cacf694a6bc2178c99320d8b987f3ebce572756" alt=""
- Following the directions on this link a bash script can be submitted as a Command Injection:
http://pentestmonkey.net/cheat-sheet/shells/reverse-shell-cheat-sheet
data:image/s3,"s3://crabby-images/fe21d/fe21d56bccf769c390d0a5633aba11c951b4aab0" alt=""
data:image/s3,"s3://crabby-images/75c97/75c97b6d71c22fe37d7866f2d0027f604e13549d" alt=""
- The reverse shell is eventually achieved at the attacker's local machine:
data:image/s3,"s3://crabby-images/696cf/696cf8a30294f3a9c2e8ea9ba69e40047de964ce" alt=""
- However, let's notice that we have a shell just for the user apache, not with root privileges, so we need to start a privilege escalation process to get a root shell.
4 - PRIVILEGE ESCALATION
- From the previous scanning whe know that the running operating system is Linux with kernel 2.6:
data:image/s3,"s3://crabby-images/0d0ec/0d0ecb7126b27006532fd9c1222488e69024b4fc" alt=""
- Googling for Kernel 2.6 vulnerability for privilege escalation:
data:image/s3,"s3://crabby-images/20ff3/20ff386315b05b4e88a947a3f4d0c4512e053f8a" alt=""
- There are some exploits useful for that purpose, for instance this one:
data:image/s3,"s3://crabby-images/57b70/57b703c220ca52206766eebc6158823f879f7f97" alt=""
- Using searchsploit to locate the exploit:
data:image/s3,"s3://crabby-images/d66e1/d66e15d042994c5e4cd21da8dafa256fe2d19c2d" alt=""
data:image/s3,"s3://crabby-images/b5db8/b5db8472d95883fa5a6568ae9d70ff2b24925e8d" alt=""
- Copying the exploit 9542.c to a testing folder:
data:image/s3,"s3://crabby-images/c770e/c770e1e890b08a0f34f3de06735d532fae65c763" alt=""
data:image/s3,"s3://crabby-images/e1157/e115729498c69b64747451091bcc41aa4297d6a0" alt=""
- Now, setting a simple server on port 8080:
data:image/s3,"s3://crabby-images/9dd91/9dd918d45fdd9885c8e504b5ce41a0668d98a317" alt=""
- Remembering that the shell was working at the /var/www/html directory, what usually does not have the needed pemissions to be written:
data:image/s3,"s3://crabby-images/1781f/1781f1c080251841a978fe8fc6f6f1524d17e082" alt=""
- However, the directory /tmp does usually have permission to be written, so it is better to use /tmp as a destination for downloading the exploit 9542.c from the attacker's side to the victim's side, where the exploit will be run:
data:image/s3,"s3://crabby-images/c4e16/c4e16758a5150baef51334ecc5e4376571004e4e" alt=""
- Now, we've got the exploit at the victim's machine:
data:image/s3,"s3://crabby-images/b0c4e/b0c4efa779295d59b068c2797d209daa7ad7bd00" alt=""
- Another option would be to download the exploit to /tmp from the original website, using the option --no-check-certificate to avoid checking the server certificate against the available certificate authorities:
data:image/s3,"s3://crabby-images/03abf/03abff21a7e506678c69ac5ca8ecd21c95d538de" alt=""
- Compiling the exploit:
data:image/s3,"s3://crabby-images/46f15/46f15c6b9b428348e0c39ff2406ccea5f9b38dd6" alt=""
data:image/s3,"s3://crabby-images/58d76/58d7673ae4a93d2dba2c5bbb0cb606d7b7afc997" alt=""
- Running the exploit the root privileges are achieved immediately:
data:image/s3,"s3://crabby-images/fec8f/fec8f0dde26d3cbe11de336d3dd4f83218bbd0e3" alt=""
5 - POSTEXPLOITATION
- With the root privileges we have access to the whole filesystem, for instance the passwords file, what could be potentially decrypted:
data:image/s3,"s3://crabby-images/d8072/d8072bcd587d32f7c2174302b49de6dd59f87d1e" alt=""
- Also, checking the index.php we find the code that explains the SQL injection vulnerability, due to the lack of proper sanitization:
data:image/s3,"s3://crabby-images/602fa/602fa23ce188c376f7f9d210ef95f58d462ffad1" alt=""
data:image/s3,"s3://crabby-images/a9241/a92416c7f206badc2e1f06b0e889340b89f9ef56" alt=""
- Also, hardcoded credentials for a user:
data:image/s3,"s3://crabby-images/5a489/5a489fd730079bbf4e8cd1e1e0d418d7272bc0a5" alt=""
- These credentials allow us to enter the MYSQL database:
data:image/s3,"s3://crabby-images/f9523/f9523874a20a28028fc1af98f332bc273494bec4" alt=""
- There are 3 databases:
data:image/s3,"s3://crabby-images/e0b60/e0b60431a7cbe0d0bbdadb461887564ca73b4def" alt=""
- Going with the first one:
data:image/s3,"s3://crabby-images/38968/3896807e18228d3b2442aee79a82e2131f7b1597" alt=""
- There is a number of tables:
data:image/s3,"s3://crabby-images/0e24e/0e24e7cc69a2d923eb03153ca30f438882f1ce2c" alt=""
- Trying to get information from the table user we discover some credentials for root and john:
data:image/s3,"s3://crabby-images/073b2/073b22bfd2fd7c0b374afbd2326dd05b47a2b1b1" alt=""
data:image/s3,"s3://crabby-images/77ad7/77ad7f1d53e6010bdad9eab41b6a1d3a09aa3679" alt=""
data:image/s3,"s3://crabby-images/8256b/8256bb58a1a2c1b855045465d139288f8ae767f7" alt=""
- In the same way:
data:image/s3,"s3://crabby-images/f3719/f371992c8d17edc06d2c150c1722de8d3e8296cc" alt=""
- Going to the other database:
data:image/s3,"s3://crabby-images/0cb8b/0cb8bbafcda946240812639da34227cae4ead9af" alt=""
- Showing the tables:
data:image/s3,"s3://crabby-images/27231/27231eab538bd0272ad3a0bc4ac6b2895acdbc0c" alt=""
- Selecting the table users:
data:image/s3,"s3://crabby-images/dce06/dce06327db2418d88d85fd723e546633d5999a2a" alt=""
- Another interesting source of information is the hidden file .mysql_history because sensitive information such as the text of SQL statements containing passwords might be written to it:
data:image/s3,"s3://crabby-images/cce6c/cce6c681193e957b82e135fce154c9d75a130769" alt=""
- Opening .mysql_history interesting credentials are found for users like john or admin:
data:image/s3,"s3://crabby-images/2466d/2466dabc9e420f9766a985105ce50be0fab164a7" alt=""
data:image/s3,"s3://crabby-images/9c2e2/9c2e21f240295e5700e3e2e5418c00f02354c71d" alt=""
data:image/s3,"s3://crabby-images/c2331/c2331faab30ea99a42150ae8fe64041af6d8d671" alt=""