How to force credentials to every Axios request
New Courses Coming Soon
Join the waiting lists
I was using Axios to interact with an API that set a JWT token.
The API returned the token in a cookie and I quickly figured I needed to set withCredentials: true
in the Axios options:
import axios from 'axios'
axios.post(API_SERVER + '/login', { email, password }, { withCredentials: true })
Otherwise the cookie would not be saved.
I also needed to set it for every other request I made, to send the JWT token to the server:
axios.get(API_SERVER + '/todos', { withCredentials: true })
Now, it’s ok for a few requests, but for many, you’d probably like to use a general configuration.
You can do it using the create()
method to create a new Axios instance you’ll then use it in your requests:
import axios from 'axios'
const instance = axios.create({
withCredentials: true
})
instance.get(API_SERVER + '/todos')
It’s also common to add a baseURL
property:
import axios from 'axios'
const instance = axios.create({
withCredentials: true,
baseURL: API_SERVER
})
instance.get('todos')
In React I used axios-hooks
, and to configure withCredentials
I used this code:
import axios from 'axios'
import useAxios, { configure } from 'axios-hooks'
const instance = axios.create({
withCredentials: true,
baseURL: API_SERVER,
})
configure({ instance })
const [{ data, loading, error }, refetch] = useAxios('todos')
→ Get my JavaScript Beginner's Handbook
→ Read my
JavaScript Tutorials
on The Valley of Code
→ Read my
TypeScript Tutorial
on The Valley of Code
Here is how can I help you:
- COURSES where I teach everything I know
- CODING BOOTCAMP cohort course - next edition in 2025
- THE VALLEY OF CODE your web development manual
- BOOKS 17 coding ebooks you can download for free on JS Python C PHP and lots more
- Interesting links collection
- Follow me on X