Similar to how we can extract session cookies from applications that do not utilize SSL encryption, we can do the same regarding CSRF tokens included in unencrypted requests.
Exploitation
Log-in to the vulnerable web app. Click and save Julie Roger’s profile.
Intercepting the profile update traffic with Burp, we will see the below:
GET /app/save/julie.rogers@example.com?telephone=1234&country=Korea&csrf=234dfg0230j23r9v032o4n0sdvsjnf2034&action=save
We can see that CSRF token is included in the GET request.
Let’s say an attacker on the local network sniffed the above request.
First, create and serve the below HTML page. Save it as notmalicious_get.html
Notice that the CSRF token’s value above is the same as the CSRF token’s value in the captured/“sniffed” request.
You can serve the page above from your attacking machine as follows.
While still logged in as Julie Rogers, open a new tab and visit the page you are serving from your attacking machine http://<VPN/TUN Adapter IP>:1337/notmalicious_get.html
. You will notice that Julie Rogers’ profile details will change to the ones we specified in the HTML page you are serving.