eLFI already solved it, better get going #BUGCROWD Challenge
data:image/s3,"s3://crabby-images/0cf92/0cf92b45300b914393d9c9521865f08c46191b8e" alt="eLFI already solved it, better get going #BUGCROWD Challenge"
In this Write-Up, I am going to walk you through the bugcrowd’s open challenge to hackers.
- Note: In case you’re reading this Write-Up without trying out the challenge. I request you to first give it a try and check this blog if you’re stuck.
1. Hint given: “i am eLFI”
2. So, I went to this link https://bugcrowd-advent-challenge.herokuapp.com/login.php
3. Tried user1 and Randompassword123 as credentials that was present on the login page itself and it gave me an internal server error as shown below.
data:image/s3,"s3://crabby-images/ae3cf/ae3cf45921bb86ee635703c260f1b21b755de513" alt=""
4. I tried to play around with the login.php but no luck.
5. I jumped right away to the view page source of the login.php application, went through the source code and few lines caught my attention which I highlighted below.
data:image/s3,"s3://crabby-images/e19d1/e19d19516c65b3e50313c1b7c4885ec6ea1dff43" alt=""
6. Then I remembered the Hint and tried to sync that with the above lines of code.
7. That’s how I found a vulnerable endpoint which is /style.php?css_file=custom.css
8. Here, when I tried to inject a random LFI payload, it showed Hacker detected, which confirmed that style.php is the vulnerable parameter.
https://bugcrowd-advent-challenge.herokuapp.com/style.php?css_file=//..//..//..//etc/passwd
data:image/s3,"s3://crabby-images/5e696/5e696086332e1ce7b854ab15bb3ddf04edea7a0a" alt=""
9. Here I guessed it is filtering out etc/passwd so I tried URL, BASE64 encoding, and double encoding, but no luck.
10. Then, I played around with the application for a while. Finally, while fuzzing the application, I observed there’s another file as index.php
data:image/s3,"s3://crabby-images/b8741/b8741b6e88eee392493c9bca63174e0a40ec75f2" alt=""
11. But when I opened it, it redirected me to the login.php. But when you open the network tab you can see the index.php and the status code as 302.
data:image/s3,"s3://crabby-images/d7478/d7478a8c7be9ae5af1c987dc5800b55b69925b12" alt=""
12. I felt a bit suspicious about this index.php and I wanted to see what is there in it. So, I googled about it.
data:image/s3,"s3://crabby-images/73077/730770197cdccf71d0a1ed24ed38f139030bcfcf" alt=""
13. I came across this piece of code php://filter/convert.base64-encode/resource=<filename>
which helped me in bypassing the restriction and allowed me to view the source code of index.php
data:image/s3,"s3://crabby-images/aa890/aa8908f199bb42fc13b77718cceb49a4b9cf108d" alt=""
14. Finally, index.php gave me some encoded string like this.
15. I decoded it using the below command. You can also use cyberchef (You can also use burpsuite’s decoder)
echo “PD9waHAKCnNlc3Npb25fc3RhcnQoKTsKc2Vzc2lvbl9yZWdlbmVyYXRlX2lkKHRydWUpOwoKaWYgKGlzc2V0KCRfU0VTU0lPTlsidXNlciJdKSl7CiAgICBoZWFkZXIoIkxvY2F0aW9uOiBkYXNoYm9hcmQucGhwIik7CiAgICBleGl0KCk7Cn1lbHNlewogICAgaGVhZGVyKCJMb2NhdGlvbjogbG9naW4ucGhwIik7CiAgICBleGl0KCk7Cn0KCj8+” | base64 — decode
data:image/s3,"s3://crabby-images/b4cc7/b4cc7f3d76f226a4d33a280947a4772e700b37ed" alt=""
16. It showed me two Php files named dashboard.php and login.php
Now, I replaced the index.php with dashboard.php and it gave me the below encoded string.
data:image/s3,"s3://crabby-images/d37b7/d37b7dd280d46ffc727c7afc43bdbcaf6dde837b" alt=""
17. This time I used cyberchef to decode, I found another file named sober.php in the source code.
data:image/s3,"s3://crabby-images/3ef29/3ef29185380866f36a598178526b98f20a556e24" alt=""
18. Now, I replaced the dashboard.php with sober.php and I found another encoded string
data:image/s3,"s3://crabby-images/05edd/05eddf294ea0146eac2529e3e07cdd5927bd49dc" alt=""
19. After decoding the string I got the below below code. Here, I found another encoded string in the multi-line comments, but this time it is small compared to the earlier encoded strings.
data:image/s3,"s3://crabby-images/b2601/b2601fcd7f95bd52f65a008fdbeb56c2448edf7f" alt=""
20. Finally, after decoding the string, I found this.
data:image/s3,"s3://crabby-images/b0d06/b0d06edf917367b807604c2eff27f4b9d5b63f94" alt=""
I don’t know why, but somehow I was attracted to this challenge and took off the first half of the day from work. Thanks to you bugcrowd : )
The challenge seems to be very simple after reading the walkthrough, but believe me, it took me a lot of brains to think and execute it.
I thank my friend Paweł Wąsik for his constant support.
References:
data:image/s3,"s3://crabby-images/69448/694487299d1804e75c67cfbd304682a62a99b34b" alt=""
Feel free to Connect with me at -
data:image/s3,"s3://crabby-images/e6ac1/e6ac1e749895cad8bcc84b64871315b8bb4ac6d2" alt=""