gpt4 book ai didi

reactjs - 如何使用 nextJS 管理 localStorage?

转载 作者:行者123 更新时间:2023-12-02 18:07:34 38 4
gpt4 key购买 nike

通常我使用 Django 和 React 创建应用程序,使用 JWT 进行身份验证。我正在测试 nextJS。我无法管理 JWT 身份验证,因为我无法访问本地存储来获取我的 2 个 token (访问+刷新)。

对于 React,我使用 axios.js:

import axios from 'axios';
import { baseURL } from './const/urls';

const axiosInstance = axios.create({
baseURL: baseURL,
timeout: 5000,
headers: {
Authorization: localStorage.getItem('access_token')
? 'JWT ' + localStorage.getItem('access_token')
: null,
'Content-Type': 'application/json',
accept: 'application/json',
'Cache-Control': 'no-cache',
Pragma: 'no-cache',
Expires: '0'
}
});

axiosInstance.interceptors.response.use(
(response) => response,
(error) => {
const originalRequest = error.config;

// Prevent infinite loops
if (
error.response.status === 401 &&
originalRequest.url === '/token/refresh/'
) {
window.location.href = '/login/';
return Promise.reject(error);
}

if (
error.response.data.code === 'token_not_valid' ||
error.response.status === 401 ||
error.response.statusText === 'Unauthorized'
) {
const refreshToken = localStorage.getItem('refresh_token');

if (refreshToken) {
const tokenParts = JSON.parse(atob(refreshToken.split('.')[1]));

// exp date in token is expressed in seconds, while now() returns milliseconds:
const now = Math.ceil(Date.now() / 1000);

if (tokenParts.exp > now) {
return axiosInstance
.post('/token/refresh/', { refresh: refreshToken })
.then((response) => {
localStorage.setItem('access_token', response.data.access);
localStorage.setItem('refresh_token', response.data.refresh);

axiosInstance.defaults.headers['Authorization'] =
'JWT ' + response.data.access;
originalRequest.headers['Authorization'] =
'JWT ' + response.data.access;

return axiosInstance(originalRequest);
})
.catch((err) => {
console.log(err);
});
} else {
console.log('Refresh token is expired', tokenParts.exp, now);
window.location.href = '/Login/';
}
} else {
console.log('Refresh token not available.');
window.location.href = '/Login/';
}
}

// specific error handling done elsewhere
return Promise.reject(error);
}
);

export default axiosInstance;

但它不适用于 nextJS。 localStorage 或 window.localStorage 未定义。我知道它不起作用,因为它试图在服务器端执行代码。如何强制它只使用客户端代码?我看到我可以使用 Effect,但我不明白如何在我的案例中使用它。

最佳答案

使用 (typeof window === 'undefined') 条件来检查您是否可以访问您可以在客户端访问但不能在服务器端访问的窗口。我经常使用它,所以它有效。例如,你可以根据条件检查做这样的事情:

// save to storage
export const saveToStorage = (key, value) => {
if(typeof window !== 'undefined') {
return window.localStorage.setItem(key, value);
}
}

// get from storage
export const getFromStorage = (key) => {
if (typeof window !== 'undefined') {
return window.localStorage.getItem(key);
}
}

关于reactjs - 如何使用 nextJS 管理 localStorage?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72927660/

38 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com