KIOPTRIX- Level 1 (#1)
- Layout for this exercise:
data:image/s3,"s3://crabby-images/d84ea/d84ea6d9c1dd2fde94068b0d25cbd20430370d1f" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Kioptrix Level 1 (#1)
- Kioptrix Level 1 (#1) can be downloaded from here:
https://www.vulnhub.com/entry/kioptrix-level-1-1,22/
data:image/s3,"s3://crabby-images/89b51/89b51246a658a693ec6a86a92b948e317c6b3394" alt=""
- Once downloaded, extracted and opened with WMware:
data:image/s3,"s3://crabby-images/9c1ab/9c1abc1b6260a41cedd926eba489460a50ef8712" 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.21, so it should correspond to the vulnerable machine Kioptrix:
data:image/s3,"s3://crabby-images/ad810/ad81056c2e40ad760028714ba93e53004f888ece" alt=""
- Scanning for versions and the operating system with Nmap:
data:image/s3,"s3://crabby-images/0a548/0a54833997787e452adf7bf9b262e60845446ce6" alt=""
- Going further with the SMB service running on port 139, using nbtscan:
data:image/s3,"s3://crabby-images/1d55b/1d55bae243fcc1442d53c883590bdecc93f24284" alt=""
- enum4linux yields information about the Samba version 2.2.1a:
data:image/s3,"s3://crabby-images/8955f/8955f9bf3682829b689353493ec6622e8536002e" alt=""
data:image/s3,"s3://crabby-images/1c7b5/1c7b503f5130881cbcce9ffc3d835ad7d39599ec" alt=""
- smbclient gives the same information:
data:image/s3,"s3://crabby-images/b9afa/b9afad2489645559001202101f49c9077563babe" alt=""
- nikto provides interesting information about vulnerabilities related with outdated Apache and OpenSSL versions, and also about existing buffer overflows:
data:image/s3,"s3://crabby-images/802b6/802b609a04bb66bf8da5a28c2e3dea1207ba2972" alt=""
data:image/s3,"s3://crabby-images/1777f/1777fb31df148b523f4be45b1a5fac514eb93d85" alt=""
data:image/s3,"s3://crabby-images/c2821/c2821d330556c51be437c2b6cc9a004c8603aaa4" alt=""
data:image/s3,"s3://crabby-images/90802/90802887d95ddc0551db222149d34bf0211dc121" alt=""
- To sum it up, the enumeration step gives us information about vulnerabilities related with outdated Apache and OpenSSL services, and also about running version of Samba.
- Let's exploit these vulnerabilities one by one.
3 - EXPLOITING OUTDATED VERSION Samba 2.2.1a
- Just Googling about potential Samba 2.2.1a vulnerabilities, we discover that there is a exploit for Samba versions below 2.2.8:
data:image/s3,"s3://crabby-images/4f163/4f1634072640e4b0bf03f195604808ccc2364e41" alt=""
data:image/s3,"s3://crabby-images/157a4/157a4fcd1ddbc74398203b34809de58632796e3c" alt=""
data:image/s3,"s3://crabby-images/2ce82/2ce8227be48aee39e048dff7767c07861acaf5a4" alt=""
3.1 - Metasploit
- There are 4 Metasploit modules related to this vulnerability:
data:image/s3,"s3://crabby-images/3a894/3a8944e3df8601f4382abf2f5236ba0d076e05fc" alt=""
- Picking up the second one, specific for Linux operating systems, we discover that the exploit is called trans2open:
data:image/s3,"s3://crabby-images/c6307/c63072a6248e31880d8a7469eb6c97e888d2819d" alt=""
- Starting Metasploit and searching for trans2open:
data:image/s3,"s3://crabby-images/21104/2110471b3269e46f80ade1c645b6337632d2e9c4" alt=""
data:image/s3,"s3://crabby-images/3d129/3d12996ae914e9ea1390375c421e7a783517fd0e" alt=""
- Using trans2open exploit:
data:image/s3,"s3://crabby-images/5309d/5309d82c27ab1b1dc83fa668cac2410e38125fd7" alt=""
- Setting remote host (192.168.1.21) plus the payload generic/shell_reverse_tcp with local host (192.168.1.17):
data:image/s3,"s3://crabby-images/a786e/a786e3340929bc012bafcd7ec7a6b6b6a693eb52" alt=""
data:image/s3,"s3://crabby-images/c7c13/c7c132b15b18b25d08d26a1e1cbcd6a50dfd6f9b" alt=""
data:image/s3,"s3://crabby-images/c598c/c598cd1ac707b2c8b5a4bf06f2ead943f8cc1d5d" alt=""
data:image/s3,"s3://crabby-images/ec032/ec03220e49c5f9107fa861368cf9da657ec7a0b1" alt=""
data:image/s3,"s3://crabby-images/b6b77/b6b776c51dc72babcd13ff4d78aa68698dfe3fe3" alt=""
- Finally running the exploit, a reverse shell with root privileges is achieved:
data:image/s3,"s3://crabby-images/59859/59859a5300f64fced2e37bc9736deee8ef70124d" alt=""
3.2 - Searchsploit
- Another approach to the Samba vulnerability would be to use searchsploit, a tool that is linked to the database exploitdb.
- The search for Samba 2.2.8 yields the exploit 10.c:
data:image/s3,"s3://crabby-images/8e75e/8e75eeb39021193d57f99badc5a8fe5ac0392b9a" alt=""
data:image/s3,"s3://crabby-images/e4fda/e4fda5c0f7e298ac1c92f675dacc47c65589d5ff" alt=""
- Copying 10.c to a temporary folder:
data:image/s3,"s3://crabby-images/87a74/87a74930ea830eb0b25fa38abfd624dbfe2e11d6" alt=""
data:image/s3,"s3://crabby-images/4c5f2/4c5f2f5d898d84175d3c77bd07a41d395426531f" alt=""
data:image/s3,"s3://crabby-images/cd575/cd5754a501f9e2d7ec8317383b88383df0e8592f" alt=""
- Compiling 10.c:
data:image/s3,"s3://crabby-images/4b68e/4b68e904276feb71ff23c6aae4b86974c67a8424" alt=""
data:image/s3,"s3://crabby-images/82a48/82a48724594d1403f77b587e7a0b068c8990ab2f" alt=""
- Running exploit 10 without parameters:
data:image/s3,"s3://crabby-images/144e4/144e469b02f6eb4d0e8edf694010f24f06884c0a" alt=""
- In this case parameters would be -b 0 (Linux), - c 192.168.1.17 (Kali's IP), - p 139 (SMB port), and target 192.168.1.21 (Kioptrix's IP):
- Running the exploit with those parameters:
data:image/s3,"s3://crabby-images/faefe/faefe6f5706ca0384ae2a57aba1dcc6ca2fe20f2" alt=""
4 - EXPLOTING OUTDATED VERSIONS Apache 1.3.20 / OpenSSL 0.9.6b
- Googling about these vulnerabilities we discover that there is a exploit for Apache mod_ssl < 2.8.7 OpenSSL:
data:image/s3,"s3://crabby-images/08d20/08d2047ed8848661c9beea801edeb831da0cf94e" alt=""
data:image/s3,"s3://crabby-images/582ad/582ad08aed3ab394727db37d6e74f462316418ab" alt=""
- Using searchsploit fo find any exploit:
data:image/s3,"s3://crabby-images/57c76/57c76706ce6ce034fbb47908c02467b09a181a25" alt=""
- Let's use the 764.c:
data:image/s3,"s3://crabby-images/fdb62/fdb62792cc206da1c4ea02e8b7725b4826cb5b83" alt=""
- Copying the exploit to a working folder:
data:image/s3,"s3://crabby-images/fe373/fe373465083544e43c7631fb703557f4f9bc4798" alt=""
- There have been a lot of implementation problems with this exploit, due to the fact that it is a very old exploit.
- Interesting discussiona about how to implement it correctly can be found here:
http://paulsec.github.io/blog/2014/04/14/updating-openfuck-exploit/
http://hypn.za.net/blog/2017/08/27/compiling-exploit-764-c-in-2017/
- In my case (Kali 2018.2) I have checked that for compiling this exploit it is better to use the package libssl1.0-dev version over libssl-dev
- Installing one version replaces the other one:
data:image/s3,"s3://crabby-images/dd466/dd4665024ac0d945eaaffd398ef05122d183025a" alt=""
- Opening the exploit, just two modifications are needed:
data:image/s3,"s3://crabby-images/c0e52/c0e52f187120ffecb4f83daf5082ff438114b15c" alt=""
- First, including these two additional headers:
data:image/s3,"s3://crabby-images/fa942/fa942a2c0e0ace98df900a966c4db0bfdc2aa785" alt=""
- Second, replacing the original http location:
data:image/s3,"s3://crabby-images/e9dfa/e9dfa92f9d13c8016fa57b0ec9c1ebce58884b4b" alt=""
- Now, compiling with option -lcrypto:
data:image/s3,"s3://crabby-images/fb4b8/fb4b89b4fe4e0e291a1d137cc52207653a3e4442" alt=""
data:image/s3,"s3://crabby-images/cf6eb/cf6ebb89d069a0237adb1757edebe9631962eeae" alt=""
- Running 764 without parameters:
data:image/s3,"s3://crabby-images/db489/db4899cd77d603791d3f4a26591584e6ad1fd44d" alt=""
data:image/s3,"s3://crabby-images/e2806/e2806503d2035262dc59724589b7b2b9668d0878" alt=""
- There are two potential valid OffSet for this exercises (0x6a and 0x6b), according to the operating system and Apache server version in use:
data:image/s3,"s3://crabby-images/b1766/b1766d92f582b6ee61afeda6b489d9b793f728e9" alt=""
- Trying 0x6a the result is unsuccessful:
data:image/s3,"s3://crabby-images/8c569/8c569f90f3aec1b54371929d09a2763fc3cdfa25" alt=""
- Trying 0x6b the result is successful and a reverse shell with root privileges is achieved:
data:image/s3,"s3://crabby-images/90a18/90a181cd1146158c6c1eb24deac1e7cf6b93d77b" alt=""
data:image/s3,"s3://crabby-images/f7f5f/f7f5f6af4c9902e96f89b86440eeb554faea1a0a" alt=""
5 - POSTEXPLOITATION
- After the vulnerable machine has been successfully exploited we can perform several postexploitation tasks.
- For instance, capturing the flag by reading /var/mail/root:
data:image/s3,"s3://crabby-images/cfa09/cfa09e17481e9d37115248e0ac250dd7243510ea" alt=""
- Acessing to /etc/shadow:
data:image/s3,"s3://crabby-images/fcbe9/fcbe9c6d28c5719f7295ee38322ce699281f21f8" alt=""
- Also, to get a bash on the local machine we could enable a listening netcat session, for instance at port 4444:
data:image/s3,"s3://crabby-images/2d08c/2d08cdacc356a5bac261973be0f9f21b3656807e" alt=""
- Following the directions on this link a bash script can be used:
http://pentestmonkey.net/cheat-sheet/shells/reverse-shell-cheat-sheet
data:image/s3,"s3://crabby-images/91f3b/91f3b44ed725c9836c136056b9f080136d84d858" alt=""
- The shell is eventually achieved at the attacker local machine:
data:image/s3,"s3://crabby-images/f21f5/f21f56db59871adc873f46534c5f6201370f36a7" alt=""