当前位置: 首页 > news >正文

郑州专门做网站的公司百度广告联盟赚广告费

郑州专门做网站的公司,百度广告联盟赚广告费,政府网站建设排名,管庄网站建设什么是 token 无感刷新?为什么需要 token 无感刷新?让我们想象一下有这么个场景:你登录一个系统成功后,玩了 10 分钟,发现登录失效了,又要你重新登录,然后又过 10 分钟,又失效了&…

什么是 token 无感刷新?为什么需要 token 无感刷新?让我们想象一下有这么个场景:你登录一个系统成功后,玩了 10 分钟,发现登录失效了,又要你重新登录,然后又过 10 分钟,又失效了,又要重新登录,难不难受,那这是怎么造成的?是因为权限 token 有效时间很短造成的,不要问,为什么权限 token 过期时间这么短,因为需要实现单点登录。那什么是单点登录呢?请参考单点登录模式。

在单点登录模式下,服务器在我们登录成功后发了两个 token 给我们,一个有效时间短的权限 token(有效时间 10 分钟),一个有效时间长的刷新token(有效时间一个月)。那这个刷新 token有啥用呢,当权限token过期后,我们可以拿刷新token再去换一个新的权限token。

现在,我们需要实现的是 token 的无感刷新,那什么是 token 的无感刷新呢,就是在权限token失效后,自动拿刷新token去换新的权限 token,拿到新的权限token后继续访问系统受保护资源。不需要用户做任何操作,完全无感。

1. 接口封装

在 refreshtoken.js 中封装刷新 token 接口。

为什么需要定义 promise,因为当权限 token 失效时,但这期间同时访问了很多需要权限 token 的接口,不可能每个接口都去调用刷新接口,如果已经在调用刷新接口了,那么就赋值给 promise,在结果没返回前,再次调用刷新接口,直接就返回 promise。

为什么需要定义 __isRefreshToken 呢,因为如果刷新 token 也不存在,那么在调用刷新接口时,就会陷入死循环,需要判断当前需要权限的接口是不是刷新接口。

// refreshtoken.js
import request from "./request.js";
import { getRefreshToken } from "./token.js";let promise = null;export const refreshToken = () => {if (promise) {return promise;}promise = new Promise(async (resolve) => {const resq = await request.get("/refresh_token", {headers: {Authorization: `Bearer ${getRefreshToken()}`,},__isRefreshToken: true,});resolve(resq.code === 0);});promise.finally(() => {promise = null;});return promise;
};export const isRefreshRequest = (config) => {return !!config.__isRefreshToken;
};

2. 封装 axios 请求

在 request.js 中封装 axios 请求

响应拦截中,后端返回的两个 token,我们都拿着保存着。当响应报 401 时,我们需要判断是不是调用刷新接口报的 401,如果不判断,就会一直在刷新接口这陷入死循环。刷新接口调用成功后,返回新 token,拿到新 token,赋值给 header,继续之前的请求。如果调用刷新接口失败,直接重新登录去。

// request.js
import axios from "axios";
import { setToken, setRefreshToken, getToken } from "./token.js";
import { refreshToken, isRefreshRequest } from "./refreshtoken.js";const service = axios.create({baseURL: "http://localhost:8080",headers: {Authorization: `Bearer ${getToken()}`,},
});// 响应拦截器
service.interceptors.response.use(async (res) => {if (res.headers.authorization) {const token = res.headers.authorization.replace("Bearer ", "");setToken(token);service.default.headers.Authorization = `Bearer ${getToken()}`;}if (res.headers.refreshtoken) {const refreshtoken = res.headers.refreshtoken.replace("Bearer ", "");setRefreshToken(refreshtoken);}if (res.data.code == 401 && !isRefreshRequest(res.config)) {const isSuccess = await refreshToken();if (isSuccess) {res.config.headers.Authorization = `Bearer ${getToken()}`;const resp = await service.request(res.config);return resp;} else {// 到登录页return res.data;}}return res.data;
});export default service;

总结:核心代码就这些,小伙伴可以根据这些代码去继续优化到自己的项目里。

http://www.dt0577.cn/news/40858.html

相关文章:

  • 凤岗金属制品东莞网站建设技术支持seo如何优化排名
  • 中国建设银行官网网站学seo如何入门
  • 公司建网站要多少钱网站关键词排名怎么优化
  • 网站过期后百度seo优化排名
  • 幼儿园校园文化设计公司靠谱seo整站优化外包
  • 腾讯云wordpress搭建网站东莞seo建站投放
  • 三级做视频网站有哪些黑龙江暴雪预警
  • 郑州网站建设设计公司seo个人优化方案案例
  • 网站后台管理界面下载免费注册推广网站
  • 深圳旅游网站建设怎样交换友情链接
  • 网站用视频做背景网络营销专业技能
  • 阿里巴巴做网站需要多少钱网站建设企业建站
  • 环保主题网站模板网络推广优化服务
  • 啥十小企业网站建设北京seo顾问外包
  • 推荐网站网页自媒体平台排名
  • 百度做的网站后台怎么建设网站优化公司哪家效果好
  • 莆田做网站公司电话seo百度发包工具
  • 电子商务物流网站建设网站手机优化
  • 北京免费网站建设模板企业网站的基本功能
  • 东莞市个性网站建设设计企业qq营销软件
  • 做微电影模板下载网站新闻投稿平台
  • 做a免费视频在线观看网站互动营销案例
  • 推广网站的方法有搜索引擎营销、邮件营销网络营销文案策划都有哪些
  • 深圳市住房和建设局领导seo网络推广方法
  • 网站外链优化传媒公司
  • 北京网站建设哪家好天googleseo服务公司
  • wordpress加qq和微信插件下载专业seo优化公司
  • wordpress 个人电脑vue seo优化
  • 网站模板免费下载网页模板电商培训机构
  • 邢台推广网站建设电话公司网站建设全包