DEV Community

Cover image for Unlocking the Secrets: Access Tokens and Refresh Tokens for Frontend Developers
Daniel Olawoyin
Daniel Olawoyin

Posted on

Unlocking the Secrets: Access Tokens and Refresh Tokens for Frontend Developers

When you’re building web applications, ensuring that users stay logged in securely is of utmost importance. As a beginner frontend developer, you’ll often work with access tokens and refresh tokens to manage user sessions. Understanding how these tokens work and how to implement them properly is essential for creating a secure and seamless user experience. In this first part of our series, we'll break down the theoretical aspects of access and refresh tokens, explaining what they are, how they function, and why they are crucial for web security. In the next part of the series, we'll see how to efficiently handle these tokens using Axios, and to round out the series, we'll explore managing these tokens with NextAuth.

Understanding Access Tokens

Access tokens are a fundamental component of web security and user session management. They are essential for ensuring that users can interact with your web application securely and efficiently. Let's dive into what access tokens are, how they work, and why they are important, using some illustrations to make it clear.

What is an Access Token?

An access token is like a digital key that allows a user to access specific resources or endpoints within a web application. It carries the user's authentication and authorization information, verifying their identity and permissions for the duration of its validity.

Key Characteristics of Access Tokens

  1. Purpose: The primary purpose of an access token is to grant access to protected resources on a server. When a user makes a request to access a resource, the access token is sent along with the request to prove the user's identity and permissions.

  2. Lifespan: Access tokens typically have a short lifespan, often ranging from a few minutes to an hour. This limited duration helps reduce the risk of misuse if the token is intercepted by a malicious actor.

  3. Format: Access tokens are usually formatted as JSON Web Tokens (JWTs). JWTs are compact, URL-safe, and self-contained, meaning they carry all the necessary information within the token itself. A typical JWT consists of three parts: a header, a payload, and a signature.

How Do Access Tokens Work?

  1. User Authentication:
  • Step 1: The user logs into the application using their credentials (e.g., username and password).
  • Step 2: The server verifies the credentials. Upon successful authentication, the server generates an access token and sends it back to the client (e.g., the frontend of the application).
    2.Accessing Protected Resources:

  • Step 1: When the user attempts to access a protected resource, the client includes the access token in the request header (usually in the Authorization header as a Bearer token).

  • Step 2: The server receives the request and validates the access token. This validation includes checking the token’s signature, expiration time, and the user’s permissions.

3.Token Expiry:

  • Since access tokens have a short lifespan, they will eventually expire. Once expired, the token is no longer valid, and the user will need to obtain a new token to continue accessing protected resources.

4.Handling Expired Tokens:

  • When an access token expires, the client can use a refresh token (if available) to request a new access token from the server without requiring the user to log in again.

Why Are Access Tokens Important?
Access tokens play a crucial role in web application security for several reasons:

  • Security: By limiting the lifespan of access tokens, the potential damage from token theft or misuse is minimized.
  • Efficiency: Access tokens allow users to access multiple resources without needing to re-authenticate each time, providing a seamless user experience.
  • Scalability: Access tokens enable stateless authentication, reducing the server's need to maintain session information, which is particularly beneficial in distributed systems and microservices architectures.

Example Scenario: Alice Logging into a School Management System

Imagine Alice, a student, logging into a school management system to check her grades, view assignments, and access other academic resources. This scenario illustrates how access tokens work in the context of a school management system.

  1. Alice Logs In to the School Management System:
  • Alice navigates to the school management system's login page.
  • She enters her username and password.
  • The school management system server verifies her credentials and, upon successful authentication, generates an access token and a refresh token.
  • The server sends these tokens back to Alice's browser.

2.Access Token Structure:
The access token Alice receives might look something like this:

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwidXNlcm5hbWUiOiJBbGljZSIsInJvbGUiOiJzdHVkZW50IiwiaWF0IjoxNjI2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c
Enter fullscreen mode Exit fullscreen mode

3.Alice Accesses Her Grades:

  • Alice clicks on the "Grades" section in the school management system.
  • Her browser sends a request to the server with the access token in the Authorization header (formatted as Bearer ).
  • The server validates the access token by checking its signature, expiration time, and Alice's permissions.
  • Upon successful validation, the server retrieves Alice's grades from the database and sends them back to her browser.

4.Accessing Other Resources:

  • Alice navigates to other sections, such as "Assignments" and "Class Schedule".
  • For each request, her browser includes the access token in the Authorization header.
  • The server performs the same validation process and returns the requested data.

5.Access Token Expiry:

  • Access tokens have a limited lifespan to enhance security. Suppose Alice's access token expires after one hour.
  • After the token expires, if Alice tries to access a protected resource, the server rejects the request and notifies the application that the token has expired.

6.Refreshing the Token:

  • To avoid making Alice log in again, her browser uses the refresh token to request a new access token.
  • The browser sends the refresh token to the server.
  • The server validates the refresh token and, if valid, issues a new access token.
  • Alice's browser receives the new access token and retries the failed request, allowing Alice to continue using the system without interruption.

Understanding Refresh Tokens

In addition to access tokens, refresh tokens play a crucial role in maintaining user sessions and enhancing security in web applications. Let's explore what refresh tokens are, how they work, and why they are essential in conjunction with access tokens.

What Are Refresh Tokens?

Refresh tokens are long-lived tokens used to obtain new access tokens after they expire. Unlike access tokens, which have a short lifespan, refresh tokens are typically valid for a more extended period, often days or even weeks. Refresh tokens are securely stored on the client-side and exchanged with the server to obtain fresh access tokens when needed.

Key Characteristics of Refresh Tokens

  • Longevity: Refresh tokens have a longer lifespan compared to access tokens. This longevity allows users to maintain their sessions over an extended period without the need for frequent re-authentication.

  • Usage: Refresh tokens are used exclusively to request new access tokens. They are not directly used to access resources but serve as a means to obtain fresh access tokens when the current ones expire.

  • Security: Refresh tokens are securely stored and transmitted between the client and server. They are typically issued with strict security measures to prevent unauthorized access and misuse.

How Do Refresh Tokens Work?

1. Initial Authorization:

  • When a user logs in or authorizes the client application, the server issues both an access token and a refresh token.
  • The access token is used to authenticate the user and access protected resources, while the refresh token is securely stored on the client-side.

2. Access Token Expiry:

  • Over time, the access token expires, typically after a short duration (e.g., one hour).
  • When the access token expires, attempting to access protected resources with it results in an authentication error.

3. Using the Refresh Token:

  • When the access token expires, the client-side application sends a request to the server with the refresh token.
  • The server verifies the refresh token's authenticity and checks if it is still valid (i.e., not expired or revoked).
  • If the refresh token is valid, the server issues a new access token to the client.

4. Continued Access to Resources:

  • With the new access token, the client can continue accessing protected resources without interruption.
  • The process repeats each time the access token expires, allowing users to maintain their session seamlessly.

Why Are Refresh Tokens Important?

Refresh tokens offer several benefits for user authentication and session management:

  • Continuous Access: Refresh tokens allow users to maintain their session and access protected resources without frequent interruptions for re-authentication.
  • Enhanced Security: By separating the access token's short-lived nature from the refresh token's longer lifespan, security risks associated with token theft or misuse are minimized.
  • Improved User Experience: Users experience fewer authentication prompts and enjoy a seamless interaction with the application, leading to higher user satisfaction and engagement.

Example Scenario: Using Refresh Tokens in a School Management System

Let's revisit Alice's scenario in the school management system and see how refresh tokens come into play:

1. Initial Authorization:

  • After Alice logs in, the server issues both an access token and a refresh token.
  • The access token allows Alice to access her grades, assignments, and other resources, while the refresh token is securely stored on her device.

2. Access Token Expiry:

  • Over time, the access token expires, and Alice's attempts to access protected resources using the expired token fail.

3. Refreshing the Token:

  • Alice's browser automatically sends a request to the server with the refresh token.
  • The server validates the refresh token and issues a new access token to Alice.
  • Alice's session continues seamlessly, and she can access the desired resources without interruption.

4. Revoking Refresh Tokens:

  • If Alice logs out or her account is suspended, the server can revoke the refresh token associated with her session.
  • Any subsequent attempts to use the revoked refresh token are rejected, requiring Alice to log in again to obtain new tokens.

In wrapping up, think of access tokens and refresh tokens as the keys and spare keys to your favorite place. Access tokens are like your main key, granting you access to different rooms or areas within the place. Meanwhile, refresh tokens act as your spare key, ensuring you never get locked out, even if your main key (access token) expires.

Understanding how these tokens work is like knowing the ins and outs of your keys – where to use them, when they expire, and how to get new ones when needed. For frontend developers, it's like being the keeper of these keys, ensuring they're safely managed and used to provide users with smooth and secure access to their digital spaces.

By mastering access and refresh tokens, developers become the guardians of user experiences, ensuring seamless interactions and safeguarding against potential security risks. It's not just about coding; it's about building trust and comfort for users as they navigate through the digital world.

Top comments (2)

Collapse
 
emiloju profile image
Edun Rilwan

Great article 👏👏. But I have a question - Is the access token also stored on the client side? If not, how is it kept so it can be used in each request to the backend?

Collapse
 
dannypreye profile image
Daniel Olawoyin

Yes, the access token is typically stored on the client side, often as a secure cookie in the user's browser. This allows it to be sent automatically with each request to the backend, ensuring that the server can authenticate and authorize the user.