vue无感刷新

干前端工作也有一小段时间了。这不,研究了下vue项目里的无感刷新。可能有经验的大佬都知道也会敲。大佬就略过吧。
vue无感刷新,大致的原理就是后端返回两个token给前端。(一个是请求的token,另一个是到期或者快到期后换取新token的那个token)

javascript 复制代码
import axios from 'axios'
import { MessageBox, Message } from 'element-ui'

//业务请求的接口
const service = axios.create({
    baseURL: process.env.VUE_APP_BASE_API, 
    timeout: 5000 // request timeout
})

//freshToken 就是当前token过期后到后端再次换取新token的接口
const freshToken = axios.create({
    baseURL: process.env.VUE_APP_BASE_API,
    timeout: 5000
})
//上面两个 service freshToken 虽然两个都是一样,但是有区别的,下面会用到





// 请求前的参数,一般我们的请求头都是在这儿设置
service.interceptors.request.use(
    (config) => {
        let token = localStorage.getItem("token")
        config.headers.Authorization = token
        return config
    },
    (error) => {
        //请求出错的处理
    }
)

//响应拦截器
service.interceptors.response.use(
    (response) => {
        //响应成功后的处理(也就是业务请求成功后的处理)
    },

    //敲黑板在这儿,重点
    async(error) => {
        //首先判断当前token是否过期,如果过期就走下面的if
        //freshToken函数也就是上面定义的换取新token的接口
        if (error.response.status == '401') {
            let newTookenObj = await freshToken({
                method: 'get',
                url: '/api/login/getNewToken'
            })
            //newTookenObj新的token
            //这儿还有一个就是换取新token之后,重新保存。
            return (error.response.config) //记住这儿一定要返回出去,也就是重新走之前请求没走完的业务
        }
    }
)

export default service
相关推荐
惜.己2 小时前
从零使用vue脚手架开发一个简易的计算器
vue·js·1024程序员节
@AfeiyuO8 小时前
el-table 表格嵌套表格
前端·elementui·vue
飞鸟真人14 小时前
VUE+Electron从0开始搭建开发环境
electron·vue
你的电影很有趣20 小时前
lesson76:Vue.js 核心特性详解:事件处理、计算属性与侦听器
javascript·vue·1024程序员节
知识分享小能手1 天前
uni-app 入门学习教程,从入门到精通,uni-app 企业项目实战:鲁嗑瓜子项目开发知识点(9)
前端·javascript·学习·微信小程序·小程序·uni-app·vue
社会底层无业大学生1 天前
uniapp微信小程序简单表格展示
微信小程序·小程序·uni-app·vue·1024程序员节
weixin_445476681 天前
Vue 项目全局水印功能完整实现指南
vue·vue2·1024程序员节
陶甜也2 天前
ThreeJS曲线动画:打造炫酷3D路径运动
前端·vue·threejs
梁辰兴3 天前
企业培训笔记:外卖平台后端--套餐管理模块--新建套餐信息
笔记·vue·mybatis·springboot·外卖管理系统
是梦终空4 天前
计算机毕业设计241—基于Java+Springboot+vue的爱心公益服务系统(源代码+数据库+11000字文档)
java·spring boot·vue·毕业设计·课程设计·毕业论文·爱心公益系统