Today I wanna share something related JSON Web Tokens (JWT).
In this writeup, I’ll tell you how I was able to confirm emails without confirmation tokens, reset password as well as taking over company emails.
So let’s start.
JSON Web Token (JWT) is an open standard (RFC 7519) that defines a compact and self-contained way for securely transmitting information between parties as a JSON object. This information can be verified and trusted because it is digitally signed. JWTs can be signed using a secret (with the HMAC algorithm) or a public/private key pair using RSA or ECDSA.
In its compact form, JSON Web Tokens consist of three parts separated by dots (
.), which are:
Therefore, a JWT typically looks like the following.
Now let’s come back to the writeup.
Here I was able to confirm emails without confirmation token by abusing invite functionality and changing JWT token.
Suppose email@example.com email is mine, I invited myself in the users and got the confirmation token in my inbox.
The response in burp was something like:
the token was something like:
Decoding the JWT token:
Now I invited firstname.lastname@example.org, the response in Burp was:
Now what I did here was changing the JSON web token that I received in my inbox.
I changed the email from email@example.com to firstname.lastname@example.org, attacker ID to admin ID and changed the timestamp to the issued timestamp as you can see in the response “created date”:”xxxxxxxx”. (Sometimes server verifies issued timestamp in order to validate the token.) I was able to confirm the user and set the password of the email@example.com.
We can use these credentials to log in to companies’ different SSO integrations like support panels etc..
This method was a bit tricky. However, I was able to reset the password of my organization users as I was able to see, their ID’s through the users’ tab and physical access of the browser history.
Now I requested a password reset link using my email firstname.lastname@example.org and reset link was:
Upon changing my ID to targeted user ID I was able to change the password.
The web app was not validating the calculated signature, thus I was able to re-encode the JWT.
For more understanding, you can have a look at:
That’s all folks!
Thanks for reading and don’t forget to share your thoughts on it.