KIOPTRIX- 2014 (#5)
- Layout for this exercise:
data:image/s3,"s3://crabby-images/80350/8035030e08a76268e35e394ccbffff7f2768a517" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Kioptrix 2014 (#5)
- Kioptrix 2014 (#5) can be downloaded from here:
https://www.vulnhub.com/entry/kioptrix-2014-5,62/
data:image/s3,"s3://crabby-images/badc9/badc9edc3ee9947eee3d76716791cb3a072a842e" alt=""
- Once downloaded, extracted and opened with WMware:
data:image/s3,"s3://crabby-images/b481f/b481f2d0d5acb97f2fa8bc3ead71743e8cc34996" 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.159, so it should correspond to the vulnerable machine Kioptrix:
data:image/s3,"s3://crabby-images/0581b/0581bbc4d3214b83876cceaf834f9fdf4e96da6c" alt=""
data:image/s3,"s3://crabby-images/fc9ac/fc9acd8499e3b580e60214aee36695074f3e847f" alt=""
- Scanning with Nmap, there are only two open ports (80 and 8080), running Apache web server.
data:image/s3,"s3://crabby-images/0eaca/0eaca68b29bf807ccc645378572e088378e37ce7" alt=""
- Also, it is interesting that the operating system is FreeBSD 7.0|8.0|9.0
- Using dirb to check the contents of the website:
data:image/s3,"s3://crabby-images/4d832/4d8326ad13afe90c43504d9e5bfb3ab4064eb989" alt=""
- Trying to connect to the web server to port 8080, there is a Forbidden message as answer:
data:image/s3,"s3://crabby-images/13f15/13f15a4aa722bf4a62127054d9929e29ce828688" alt=""
- Trying to connect to the web server to port 8080, It works !
data:image/s3,"s3://crabby-images/e4d4e/e4d4e55da97f961bb77f8cbdf4aec5aabeea28b5" alt=""
- Viewing the Page Source, we detect the presence of pChart2.1.3:
data:image/s3,"s3://crabby-images/6e07a/6e07a12e1d2f74f6e56600475eeb727befd79d30" alt=""
data:image/s3,"s3://crabby-images/ff025/ff0253cb6d1b940e34597bb539f95d6307ed4213" alt=""
- pChart is a PHP library that helps to create anti-aliased charts or pictures directly from the web server.
http://www.pchart.net/
- Going deeper into folder pChart2.1.3:
data:image/s3,"s3://crabby-images/1dc0a/1dc0aaef23c69b1081c459afd62e5c9a9a5ef966" alt=""
data:image/s3,"s3://crabby-images/68d58/68d5816bbadc5dac4ca85eb38ce25da9336554be" alt=""
- For instance, connecting to folder /examples:
data:image/s3,"s3://crabby-images/47105/471059eec06609067dce7ac0b2661705db51c47f" alt=""
3 - EXPLOITATION
- First, let's see if there is any pChart 2.1.3 related vulnerability:
data:image/s3,"s3://crabby-images/d623a/d623a3230757a3e47c7b15093cc3c49301248bee" alt=""
- It seems that there are a numbers of vulnerabilities affecting the /examples folder:
data:image/s3,"s3://crabby-images/3582c/3582c991129bc5d66f76adb231d6ae98e18e9a53" alt=""
- Let's focus our attention on the Directory Traversal attack:
data:image/s3,"s3://crabby-images/00e9c/00e9c69ebb5ad77e5a59e90689390147bc56fe08" alt=""
- Crafting the Directory Traversal URL to our needs:
data:image/s3,"s3://crabby-images/55a4c/55a4c90840a08a61bc50a02355eaa0db4b04b925" alt=""
- The attack is successful:
data:image/s3,"s3://crabby-images/72e63/72e63dd2964bde5645d31f27d6e6189574fb3309" alt=""
- At this point let's remember (from Namp) that we are dealing with FreeBSD 7.0|8.0|9.0 operating system and Apache 2.2.21 web server.
- The configuration file for this type of operating system and web server can be found at /usr/local/etc/apache22/httpd.conf:
https://www.freebsd.org/doc/handbook/network-apache.html
- Now, let's craft the URL to see what we can learn from httpd.conf:
data:image/s3,"s3://crabby-images/ae823/ae8237e49c36b0ca5a599fa9d73050fc4471719f" alt=""
- The Directory Traversal attack is again successful:
data:image/s3,"s3://crabby-images/8fd00/8fd005596b3200087f26cea106803a2ee38ec9c1" alt=""
data:image/s3,"s3://crabby-images/1fc05/1fc05d6bd724a18955bf4b12a04b2a825e102064" alt=""
- Let's notice the last part of the output, where it seems that for successfully connecting to the port 8080 the User-Agent must be mandatory Mozilla/4.0
- Connecting to 192.168.1.159:8080 with curl and specifying "User-Agent:Mozilla/4.0" the element phptax appears:
data:image/s3,"s3://crabby-images/ca4ab/ca4abe8de448684cfe1cc48fb805010dbb51633b" alt=""
- phptax is an old web application to calculate US income return.
- Now, we must change the default Mozilla version to the needed 4.0. For that purpose, opening about:config and accepting the risk:
data:image/s3,"s3://crabby-images/28de4/28de44d7c53c32f2f3cbdad154fab57cbe7159d0" alt=""
- Searching for useragent and opening a new String:
data:image/s3,"s3://crabby-images/ea991/ea99135264641f9c378df7421d33f4f30570bb6e" alt=""
- Writing a new string and its value:
data:image/s3,"s3://crabby-images/aa8c4/aa8c464ec980c7f96406aef9a21d6b8b34a260ba" alt=""
data:image/s3,"s3://crabby-images/4ac79/4ac792370ed5e79e6156cd04819604341df8bdd4" alt=""
- Now, the connection to 192.168.1.159:8080 is successful and phptax is indexed:
data:image/s3,"s3://crabby-images/b7a1b/b7a1bf7ad03b3ddc5ed20638630f5359bf6cc257" alt=""
data:image/s3,"s3://crabby-images/c0b5f/c0b5f5cc84cee4556f6878da76500e2763368df0" alt=""
- Metasploit helps to exploit phptax:
data:image/s3,"s3://crabby-images/e18b0/e18b07d2ca15f48b5cd465c6676efa7422086b12" alt=""
data:image/s3,"s3://crabby-images/e07df/e07dfecf0112ba16173b8f1488b9c42f63ef216c" alt=""
data:image/s3,"s3://crabby-images/7c6cf/7c6cf4ed2158eb549257daade6df495ca8b48a64" alt=""
- Setting options:
data:image/s3,"s3://crabby-images/7fafe/7fafed892f4bbca28e32ccda0375fb9deccc17fd" alt=""
- Running the exploit a limited shell is achieved for user www:
data:image/s3,"s3://crabby-images/fd4a2/fd4a211ed5391ba307c42a5baf64dde52443aa40" alt=""
4 - PRIVILEGE ESCALATION
- Getting an sh shell:
data:image/s3,"s3://crabby-images/cc388/cc388bd2124bb628239dd8e87cec258c4cbc5305" alt=""
- Remembering that the operating system is FreeBSD 9.0:
data:image/s3,"s3://crabby-images/03ff5/03ff54565653d9380fade6863f275215b8c06a5c" alt=""
- Googling for FreeBSD 9.0 vulnerabilities:
data:image/s3,"s3://crabby-images/0dcb4/0dcb465d869a8559d3fb8ab1e4478c864a47ecbf" alt=""
- There is an interesting one for Privilege Escalation:
data:image/s3,"s3://crabby-images/628fe/628fe0db86da3ed4e51adb849be8729e7e4c7547" alt=""
- Downloading the exploit and copying to a working directory:
data:image/s3,"s3://crabby-images/b19f0/b19f0d87b426e1bfd7bd84b7998a0bf0f61ca355" alt=""
- Setting a netcat listening session with the purpose of transferring the exploit to the victim machine:
data:image/s3,"s3://crabby-images/8db85/8db85c7128639de6f133ecd92daf90d6c4928219" alt=""
- Doing the same thing at the victim's side (/tmp is writeable) the transfer is finally successful:
data:image/s3,"s3://crabby-images/8705c/8705c789f02b642d75f688c6f80ffc8844a20c37" alt=""
data:image/s3,"s3://crabby-images/86a67/86a67e55ae5ccb0d4e5390b184a6334e34c0f89e" alt=""
- Listing the exploit:
data:image/s3,"s3://crabby-images/2383c/2383c1791280d767be2f1e71a9afb2da97c98c04" alt=""
- Compiling:
data:image/s3,"s3://crabby-images/fcdf0/fcdf0e3e71b77aad61499bcc9e2dbb01c0bcbda1" alt=""
data:image/s3,"s3://crabby-images/bb618/bb61854488216b9b102166b9df84003c144459f3" alt=""
- Running the exploit a root shell is achieved:
data:image/s3,"s3://crabby-images/7503c/7503c3cafa59a05b4a3acbcdb23d689f224ab4c8" alt=""
5 - CAPTURING THE FLAG
- Going to the /root folder:
data:image/s3,"s3://crabby-images/bd93c/bd93c121d83303b940396aeab5235305364dfab0" alt=""
data:image/s3,"s3://crabby-images/72300/723002aa9d42194fb8bdae589bbd3c758cf05717" alt=""
etc ...