axios利用Promise刷新token实战
5星 · 超过95%的资源 186 浏览量
更新于2024-08-31
收藏 85KB PDF 举报
"本文介绍了如何利用axios和Promise无痛刷新token的实现方法,主要涉及两种不同的策略:请求前拦截和响应后拦截。文章通过具体的代码示例详细解释了这两种方法的优缺点,并选择了响应后拦截的方法进行实现。"
在前端开发中,与服务器交互时,token的管理是一个重要的环节。`axios`是一个常用的JavaScript库,用于处理HTTP请求。当用户的token过期时,通常需要刷新token以保持会话状态。为了确保用户体验,我们需要在刷新token的过程中尽量减少对用户的影响,这就是所谓的“无痛刷新”。
文章提出的两个主要实现思路:
1. 请求前拦截:在每个请求发送前,检查token是否过期。如果过期,先发起刷新token的请求,获取新token后再继续原请求。这种方法的优点是减少了不必要的网络请求,但缺点是依赖于本地时间的准确性,可能存在本地时间篡改导致的拦截失败风险。
2. 响应后拦截:先发送请求,当服务器返回提示token过期时,再刷新token并自动重试请求。这种方法简单直接,但会增加一次网络请求。
考虑到实际应用中,用户篡改本地时间的情况较少,作者选择了响应后拦截的方法,使用`axios.interceptors.response.use()`来处理。这种方式可以避免因时间判断错误导致的问题,但在某些情况下可能会多消耗一次请求。
以下是一个简单的axios响应拦截器实现token刷新的示例:
```javascript
axios.interceptors.response.use(
response => {
// 如果请求成功,直接返回响应
return response;
},
error => {
if (error.response.status === 401) { // 当状态码为401,表示未授权,可能是因为token过期
return new Promise((resolve, reject) => {
// 发送刷新token的请求
refreshToken().then(newToken => {
// 存储新token,并更新axios配置
saveToken(newToken);
axios.defaults.headers.common['Authorization'] = 'Bearer ' + newToken;
// 用新token重试原请求
axios(error.config).then(resolve).catch(reject);
}).catch(() => {
// 刷新token失败,处理错误,例如跳转到登录页
handleTokenRefreshFailure();
});
});
} else {
// 其他错误,直接抛出
return Promise.reject(error);
}
}
);
```
在这个示例中,`refreshToken()`函数负责发送刷新token的请求,成功后返回新的token。`saveToken()`函数用于存储新token,可能是保存在localStorage或cookie中。`axios.defaults.headers.common['Authorization']`设置为新token,确保后续请求带有新token。如果刷新token失败,`handleTokenRefreshFailure()`函数会处理这种情况,比如提示用户重新登录。
通过响应拦截器,我们可以优雅地处理token过期的情况,确保用户在大部分时间里不会感知到这种异常,从而提高应用的用户体验。
2020-11-19 上传
2020-11-21 上传
2023-09-01 上传
点击了解资源详情
2023-09-09 上传
2024-08-01 上传
2024-01-16 上传
2020-12-09 上传
weixin_38693419
- 粉丝: 6
- 资源: 930
最新资源
- 黑板风格计算机毕业答辩PPT模板下载
- CodeSandbox实现ListView快速创建指南
- Node.js脚本实现WXR文件到Postgres数据库帖子导入
- 清新简约创意三角毕业论文答辩PPT模板
- DISCORD-JS-CRUD:提升 Discord 机器人开发体验
- Node.js v4.3.2版本Linux ARM64平台运行时环境发布
- SQLight:C++11编写的轻量级MySQL客户端
- 计算机专业毕业论文答辩PPT模板
- Wireshark网络抓包工具的使用与数据包解析
- Wild Match Map: JavaScript中实现通配符映射与事件绑定
- 毕业答辩利器:蝶恋花毕业设计PPT模板
- Node.js深度解析:高性能Web服务器与实时应用构建
- 掌握深度图技术:游戏开发中的绚丽应用案例
- Dart语言的HTTP扩展包功能详解
- MoonMaker: 投资组合加固神器,助力$GME投资者登月
- 计算机毕业设计答辩PPT模板下载