技术文摘
Vue3 与 Vite 如何利用双 token 达成无感刷新
2025-01-10 20:50:28 小编
在现代Web应用开发中,用户体验至关重要。Vue3 与 Vite 的组合为开发者带来了高效且优质的开发体验,而利用双 token 实现无感刷新更是提升用户体验的关键一环。
我们要明白什么是双 token。通常,双 token 指的是 access token 和 refresh token。access token 用于验证用户在短期内的操作权限,而 refresh token 则在 access token 过期时,用于获取新的 access token,从而避免用户因 token 过期而被强制重新登录。
在 Vue3 与 Vite 的项目中,实现双 token 无感刷新,我们需要几个关键步骤。
第一步是登录获取双 token。在用户登录成功后,服务器会返回 access token 和 refresh token。我们可以将这两个 token 存储在本地,比如使用 localStorage 或 Vuex 来管理。例如,在 Vuex 的 mutations 中定义存储方法:
const mutations = {
SET_ACCESS_TOKEN(state, token) {
state.accessToken = token;
},
SET_REFRESH_TOKEN(state, token) {
state.refreshToken = token;
}
};
接着,在每次发送请求时,我们要在请求头中带上 access token。可以通过创建一个拦截器来实现。在 Vite 项目中,使用 axios 时,可以这样设置:
import axios from 'axios';
const instance = axios.create();
instance.interceptors.request.use(config => {
const accessToken = localStorage.getItem('accessToken');
if (accessToken) {
config.headers.Authorization = `Bearer ${accessToken}`;
}
return config;
}, error => {
return Promise.reject(error);
});
当服务器返回 401 状态码,表示 access token 过期时,我们需要利用 refresh token 去获取新的 access token。这时候可以在响应拦截器中处理:
instance.interceptors.response.use(response => {
return response;
}, async error => {
if (error.response.status === 401) {
const refreshToken = localStorage.getItem('refreshToken');
try {
const res = await axios.post('/api/refresh', { refreshToken });
const newAccessToken = res.data.accessToken;
localStorage.setItem('accessToken', newAccessToken);
error.config.headers.Authorization = `Bearer ${newAccessToken}`;
return instance(error.config);
} catch (err) {
// 处理 refresh token 也过期的情况,引导用户重新登录
}
}
return Promise.reject(error);
});
通过以上步骤,我们就能在 Vue3 与 Vite 的项目中实现双 token 的无感刷新,为用户提供更加流畅的使用体验。
- 为何在有二叉查找树和平衡树的情况下还需要红黑树
- Go 中的内联优化策略
- 优质代码轻松实现的九步秘诀
- 三行 Python 代码实现多 Excel 文件合并
- Bug 导致误执行 rm -fr /*,令人瞬间背后发凉!
- Go 中栈内函数的内联处理
- 这些高效代码小技巧令人相见恨晚,你知晓吗?
- 此次,彻底讲清 synchronized 与锁的关系
- 25 种绝佳 VSCode 扩展,尽享便捷高效
- Python 助力实时监控,不再担忧他人动电脑
- JS 图片压缩的实现方法
- Python 线程安全那些事
- 几步轻松让你的 JS 书写更美观
- 9 个 Web 开发人员必备的 CSS 工具
- Go 服务乱码导致的线上事故