BRAINPAN 1
- Layout for this exercise:
data:image/s3,"s3://crabby-images/7b01f/7b01f60d53862dda0b135b1c2174f6cc41ebb0cc" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Brainpan 1.
- Brainpan 1 can be downloaded from here:
https://www.vulnhub.com/entry/brainpan-1,51/
- Once downloaded and imported with VMWare:
data:image/s3,"s3://crabby-images/9934e/9934e1d70a5b3abdbf7e58baea409430e36e4f0a" alt=""
2 - ENUMERATION
- netdiscover helps us to discover that Brainpan's IP is 192.168.1.26:
data:image/s3,"s3://crabby-images/19c8b/19c8b954b1203c64c29a7ea9c8bcc0093b12755e" alt=""
- Nmap finds two open ports: 9999/tcp and 10000/tcp:
data:image/s3,"s3://crabby-images/7419d/7419d71d7fc7a6d6d811e22c31ddec1fcd0cb7b5" alt=""
- Connecting with the browser to port 10000:
data:image/s3,"s3://crabby-images/87514/87514a7ad0d322c7b09722cd7c6ab8c52402e49b" alt=""
- dirb scans the web server and finds the folder /bin:
data:image/s3,"s3://crabby-images/59ca6/59ca64c6a8e8f157dd3ff264131c78c8f9545338" alt=""
- Connecting to /bin with the browser there is an executable called brainpan.exe:
data:image/s3,"s3://crabby-images/20ddd/20ddd30655cc78b3762351d6fc6c2c87011fd067" alt=""
- Downloading brainpan.exe to Kali:
data:image/s3,"s3://crabby-images/7cee6/7cee6b03d0a224461271d0819dd49f9871b65204" alt=""
- Let's notice that it is a Windows executable file:
data:image/s3,"s3://crabby-images/efd08/efd08800c64c959209deae32a1d65d4cc19f835d" alt=""
- Searching for strings inside brainpan.exe there are some functions prone to suffer from Buffer Overflow attacks:
data:image/s3,"s3://crabby-images/09dc4/09dc489809ccc16d653ce7a8f57debd2741fe9cb" alt=""
..............
data:image/s3,"s3://crabby-images/3e682/3e68248b4e64e3921f68383141687f83009ca55b" alt=""
...............
- Connecting with the browser to the other open port 9999:
data:image/s3,"s3://crabby-images/a5441/a5441f0a53ad365d305f64af50209e3bd1d39f8f" alt=""
- Let's connect again to port 9999, now with netcat. Entering a random password the acces is denied:
data:image/s3,"s3://crabby-images/4ac7b/4ac7bfbbcaf7e94906aca36b149e882720d3f571" alt=""
3 - EXPLOITATION
3.1 - ANALYZING BRAINPAN.EXE AT WINDOWS 10 WITH IMMUNITY DEBUGGER
- With the purpose of analyzing in deep the executable brainpan.exe let's move the file to a Windows environment like a Windows 10 machine:
data:image/s3,"s3://crabby-images/f2a4b/f2a4bbf96d973a90f6637f66696400def099dd30" alt=""
data:image/s3,"s3://crabby-images/dfa7d/dfa7dab0cdddb450c00b37171616a93fe33408a1" alt=""
data:image/s3,"s3://crabby-images/659e1/659e15cde3072dc4aa65837c9b8d4f0916c805ed" alt=""
3.1.1 - Finding the password
- Opening and running brainpan.exe with Immunity debugger it is pretty obvious that the string shitstorm is compared with other string using the function strcmp:
data:image/s3,"s3://crabby-images/7a48e/7a48e04172fea53d7775aa9dffca77504b9e1171" alt=""
data:image/s3,"s3://crabby-images/65afc/65afc3871507ac7d9e8d9b54147eed55263e975e" alt=""
- This leads us to guess that shitstorm can be the password to enter the application:
data:image/s3,"s3://crabby-images/f1ba2/f1ba2458f0115342ae8bf5efee8fcc584bb110a4" alt=""
- Our guess was correct because now the access is granted.
3.1.2 - Buffer overflow
- As we discovered at the Enumeration step brainpan.exe contains some strings like strcpy prone to suffer from a Buffer Overflow exploitation.
- First of all, let's create a Python script to cast a long list of "A"s over brainpan.exe:
data:image/s3,"s3://crabby-images/18232/1823259d42199e4a6d176e8cbb63e6f0eb2b1617" alt=""
data:image/s3,"s3://crabby-images/dec5e/dec5e1a89f5a32f37fdd5f111c037c5bbe42cb31" alt=""
- Giving execution permissions to exploit_windows.py:
data:image/s3,"s3://crabby-images/3a875/3a87594af507617bbc5302628146a8145ce923b4" alt=""
- Opening and running brainpan.exe with Immunity Debugger:
data:image/s3,"s3://crabby-images/c2075/c207575986f3758a32c7321beb0c75e77533b7ae" alt=""
- Launching the exploit over the Windows 10 machine:
data:image/s3,"s3://crabby-images/b8beb/b8bebb871f41bff0ec1fbbecfe5fce03e39b23ff" alt=""
data:image/s3,"s3://crabby-images/d8c66/d8c66805fbd60a250a4cad19c685a9e0c3cc3006" alt=""
- The EIP and the stack are overwritten with "A"s:
data:image/s3,"s3://crabby-images/7d31e/7d31e4b0fc2012fe5a7bdc95759a588c1d25ada3" alt=""
data:image/s3,"s3://crabby-images/95fae/95fae4ada3593a2b921a35b854ba33e7f70c7714" alt=""
data:image/s3,"s3://crabby-images/7defc/7defc8e1becf7db98e10ac43c40f5657ceebe8de" alt=""
- Creating a pattern with lenght 1000 and inserting it at the exploit:
data:image/s3,"s3://crabby-images/2b5e8/2b5e89eee5d64a864ec237f51bcc6c62e0acc57f" alt=""
data:image/s3,"s3://crabby-images/56d14/56d14a707e628c05df80d7f1946b53adcca0e51b" alt=""
data:image/s3,"s3://crabby-images/0d11f/0d11f1ea261841ccf41c00d59081bdab63e895cb" alt=""
- Restarting brainpan.exe with Immunity Debugger and launching the exploit:
data:image/s3,"s3://crabby-images/46181/46181f7c8eff82349c474ace5dbad1ee923a60d1" alt=""
- The EIP is overwritten with 35724134:
data:image/s3,"s3://crabby-images/f72af/f72af7e6b94deebad7df9fe08af9dd284088df8f" alt=""
data:image/s3,"s3://crabby-images/2b4ad/2b4ad8a06c1d55195f3f038bb780c40fa7652acc" alt=""
data:image/s3,"s3://crabby-images/d7271/d7271b43494c465c221055098fbdadc57b2bee80" alt=""
data:image/s3,"s3://crabby-images/9a9f5/9a9f528cbbe591bff8b47911980382410510e839" alt=""
- Finding an offset of 524 for 35724134:
data:image/s3,"s3://crabby-images/b11e5/b11e5266a3488685f958e56e664b5de83be56fdc" alt=""
- Now, let's redo the script in this way:
data:image/s3,"s3://crabby-images/eb674/eb674872b94e73ac88e8bba174a966c35e2ef161" alt=""
data:image/s3,"s3://crabby-images/b24b5/b24b5e517d93192d7821f5f7bb25b43deca2e518" alt=""
- Restarting brainpan.exe with Immunity Debugger and launching the last version of the exploit:
data:image/s3,"s3://crabby-images/f74e5/f74e58285a116111c6e13128b9fe5d94b8bcaa78" alt=""
- The result is that the EIP is overwritten witn BBBB, as expected:
data:image/s3,"s3://crabby-images/a4854/a4854c4f4e2d378c7a6b98deae2d12a316264754" alt=""
data:image/s3,"s3://crabby-images/e152e/e152e86f0a3cc358b20783cd2534678331d691a8" alt=""
data:image/s3,"s3://crabby-images/f1070/f10708789d42aba08ad7c979bad98f269cee9012" alt=""
- Looking for a command JMP ESP, we find it at the address 311712F3:
data:image/s3,"s3://crabby-images/0d7a1/0d7a1caca1e8a8e8b7938b38644f065565a72101" alt=""
data:image/s3,"s3://crabby-images/e7550/e7550d40201745f4e1f633a63582a31af8dd238a" alt=""
- The address 311712F3 should replace the string BBBB where the EIP is overflown, entered with Little Endian formart: \xF3\x12\x17\x31
- Creating a shellcode to achieve a reverse shell at Windows 10 machine on port 4444:
data:image/s3,"s3://crabby-images/9a631/9a631a76cca081eb3542e60ffe95154b5eccad9e" alt=""
- Also, after the JMP ESP command a bunch of NOP instructions must be used to make it easier the execution of the shellcode.
- Joining everything at the script exploit_windows.py:
data:image/s3,"s3://crabby-images/4863b/4863b59e7fdbd0b0cefbff86585c63d9edc1af30" alt=""
data:image/s3,"s3://crabby-images/95572/9557278b37ab5da5a47b752a9c8e5cdf6f1d05e2" alt=""
- Setting a listening session with Netcat:
data:image/s3,"s3://crabby-images/9fd61/9fd6143d72094e34eb33cd1a8ed4bf74f16244b6" alt=""
- Launching the exploit for last time:
data:image/s3,"s3://crabby-images/51f6a/51f6a4e9137f72ee4141180a9be62e0817d2d809" alt=""
- The exploit is successful and we have at Kali a remote shell from Windows 10:
data:image/s3,"s3://crabby-images/704c1/704c1ef7787ac164ae8920f6cdb43c943645c90e" alt=""
- Output from Immunity Debugger:
data:image/s3,"s3://crabby-images/d30d1/d30d1696a0e3045ce9cb1f34b762f068bb464ff8" alt=""
3.2 - EXPLOITING BRAINPAN
- Now, let's change the former Windows shellcode with another one for Linux:
data:image/s3,"s3://crabby-images/f5e88/f5e88ad857c808f7834313f7c823e1eaebc2c951" alt=""
- Inserting the shellcode for Linux into a new exploiting script (just changing the shellcode):
data:image/s3,"s3://crabby-images/b7b5e/b7b5e1c238436d4acb7720057ac44dae81dc7c16" alt=""
data:image/s3,"s3://crabby-images/dc5db/dc5db2da9adc8966df7a535ba7eead76b1f2a083" alt=""
- Giving execution permissions:
data:image/s3,"s3://crabby-images/8e9e2/8e9e23c6b38eba3406c81fb56409bfa6bfb98efd" alt=""
- Setting a listening session with netcat on port 5555:
data:image/s3,"s3://crabby-images/e3d37/e3d37929bac189750ccda838609e2f14b903cd82" alt=""
- Launching the exploit against Brainpan:
data:image/s3,"s3://crabby-images/9f0be/9f0be451a3ad96be90c91f1b7b63ecc4e52f5b71" alt=""
- The exploit is successful because a low privilege shell is achieved:
data:image/s3,"s3://crabby-images/3084c/3084ca465fac22b5c8a499858156321138785d69" alt=""
- Improving the shellcode:
data:image/s3,"s3://crabby-images/3af95/3af95944d38dd6552fad7276af85ed2b84329d6b" alt=""
4 - PRIVILEGE ESCALATION
- So far we have a limited shell:
data:image/s3,"s3://crabby-images/62eb6/62eb692d70ef49631bd13836bc92f20052f86a56" alt=""
- Checking user puck's sudoer permissions, we discover that he is able to run as a root without password the command anansi_util:
data:image/s3,"s3://crabby-images/a5851/a58511da10f9215480c391e26d9192c9428b8550" alt=""
- Let's run it:
data:image/s3,"s3://crabby-images/73873/7387366b342dbeccc74b3597e3db693ef73d71a6" alt=""
- There are 3 options, it seems that the most interesting could be manual [command], what invites to enter a command, like for instance let's try pwd:
data:image/s3,"s3://crabby-images/2a8aa/2a8aa8c99f2cdadfd8c429f5e31410ae9af92347" alt=""
data:image/s3,"s3://crabby-images/7c9d1/7c9d1f55ab21668298fcc47bb9c9ccd2ff8d620c" alt=""
- The result is the man page for the command pwd.
- However, because the command has been executed as a root, and remembering that man allows to execute additional inline commands starting with !, let's try !/bin/sh:
data:image/s3,"s3://crabby-images/bed2a/bed2a67d3b1e72cc9bede163c72ab878e2e09096" alt=""
data:image/s3,"s3://crabby-images/02e19/02e19e91b66c7719af6be86a36c34141031fab2e" alt=""
- Great, eventually we have a root shell:
data:image/s3,"s3://crabby-images/2147a/2147a01b8ccdd882cbac0a4c0e01205e2f914f58" alt=""
- The purpose of executing inline commands from man with ! is just to test those commands without exiting the man page.
- In our case it has been of great help for achieving a quick and easy Privilege Escalation, due to the fact that man has been executed with root privileges.5 - CAPTURING THE FLAG
- We find the flag by reading b.txt:
data:image/s3,"s3://crabby-images/4a1a4/4a1a4fd87e311ce4fb73b19cdc979e0a5a57d953" alt=""