Introduction
JWT authentication and session authentication are ways to authenticate users of your web app.
In this article we will explain the details of JWT, its structure along with its pros and cons.
JWT stands for JSON Web Token, and it is a commonly used stateless user authentication standard used to securely transmit information between client and server in a JSON format.
A JWT is encoded and not encrypted by default.
It is digitally signed using a secret key known only to the server.
It can be encrypted, but for this article we will focus on signed non-encrypted tokens.
Structure of JWT
A JSON Web Token consists of 3 parts separated by a period.
The header, the payload, and the signature.
Each section is base64 encoded.
Header
The header consists of token type, which is JWT, and the signing algorithm used, such as HMAC SHA256 or RSA.
{
"typ": "JWT",
"alg": "HS256"
}
Payload
The payload consists of the claims.
Claims are statements about the user, and additional data.
For example, we have the time the token was issued at.
We also have its expiration time, because tokens should expire.
{
"iss": "example_issuer",
"sub": "user_id123",
"exp": 1644768000,
"iat": 1644744000
}
Signature
The signature is most important part of a JWT.
It is calculated using the header, the payload, and the secret, which are fed to the signing algorithm to use.
signature = HMAC-SHA256(base64urlEncode(header) + "." + base64urlEncode(payload), secret_salt )
Steps
The steps involved in a typical JWT authorization flow are as follows:
1- Authentication: The user signs in using username and password, or using for example Google or Facebook.
The server verifies the provided credentials.
2- Token Generation & sending token to client: The server will generate the JWT and send it to the client, which stores it for future use.
3-Sending the Token to server: When the client wants to access a protected resource on the server, it sends the JWT in the Authorization header of the HTTP request.
axios.get(URL, {
headers: {
'Authorization': 'Bearer ' + token,
},
})
4-Verifying the Token: The server receives the request and verifies the JWT by checking its signature using the secret key that was used to sign it.
If the JWT is valid, the server extracts the information contained in it and uses it to determine what actions the user is authorized to perform.
5- Authorizing the Request: If the user is authorized to access the resource, the server returns the requested data. If the user is not authorized, the server returns an error message.
Advantages
Lightweight
Portable: can be processed on multiple platforms, web and mobile.
JSON parsers are common in most programming languages.
Protected against tampering because of the secret key stored on server side.
The server does not need to store any session information, because of the stateless nature of the JWT token.
Disadvantages
- On server side, should manually mark non-expired JWT as invalid on logout. A JWT can still be valid even after it has been deleted from the client.
A method used is token blacklisting, which involves maintaining a list of invalidated tokens on the server side, preventing their reuse for authentication.
For signed non encrypted tokens, we should not store sensitive info because JWT is protected against tampering but can be decoded and read by anyone.
Can provide full access if intercepted. Thatβs why JWTs on client side should be stored somewhere secure, for example in the browser in an HttpOnly cookie.
My other articles:
Top comments (12)
"JWT is protected against tampering" true to a limited extent
scenario 1:
the app gets a token from the server, but a proxy(like burp) intercepts the token then
decodes the payload, alters parameter(s) for example some user id parameter like email for example then passes the token to the app, since the app more than likely does not check the signature( usually verify is on the back-end) the app will now make a state update on altered user data
scenario 2:
their is a bunch of attacks based on the "algo" parameter
strongly advise working on the premise the JWT has been tampered with and coding defensibly against this, for example scenario 1, resend the JWT back to the back-end for verification before app state update
You described MITM attack where malicious proxy can read and modify arbitrary data between client and server. If client sends back to the server jwt token for verification, what prevents proxy from intercepting this request and spoofing the response?
u are correct nothing stops this,hopefully you can see that just trusting that the jwt is valid is an error, basic idea is if you get a jwt that does not verify on the server then this is a red flag that you are under attack and you then implement defensive code, which is better than just hoping everything is ok, as to spoofing the response need correct headers
Hey cool video! I did learn new stuf and it was very interesting!
If you let me give you a bit of feedback, in some parts the contrast of some text wasn't so good, let me show some examples:
Maybe bolder text or more light colors, keep in mind that I watched most of the video in a small size (not full screen). Hope this helps.
But it was a very cool video!
Great content to learn about JWT. I need more content like this. Appreciate it and Thank you providing such a beautiful content.
JWT is one of those subjects I keep having to re-learning every few years since I donβt need to implement it often. When itβs already working you donβt have to worry about it. Overall, great video animation and write-up! It definitely beats reading the standard for getting a quick summary.
Hi,
'4-Verifying the Token'. - does this involve calling the 'auth server'?
Thanks
this is important step that is totally missing in this article.
JWTs are very common (too common?), but have also been harshly criticized by security professionals; see end of:
What are JWT?
Thomas Broyer γ» Nov 29 '23
Very nice article. Do you have it in PDF or eBook ?
Nice article, thanks for sharing !
Some comments may only be visible to logged-in visitors. Sign in to view all comments.