Vue中的请求拦截器

目录

[1 前言](#1 前言)

[2 使用方法](#2 使用方法)

[2.1 创建拦截器](#2.1 创建拦截器)

[2.2 引入拦截器](#2.2 引入拦截器)


1 前言

我们常常会使用JWT令牌来验证登录,因此很多请求都需要携带JWT令牌,我们当然可以用{headers:{Authorization:xx}}的方式,向每个请求中都以这样的方式添加JWT令牌。不过这样做就过于繁琐,因此我们可以采用请求拦截器的方式来简化操作。

2 使用方法

2.1 创建拦截器

在src目录下,创建一个utils文件夹,再向其中创建一个request.js文件

javascript 复制代码
//创建公共前缀
const baseURL = '/api';
const instance = axios.create({ baseURL });

//请求拦截器
instance.interceptors.request.use(
    (config) => {
        //其它代码...
        //其中tokenStore.token为JWT令牌
        if (tokenStore.token) {
            config.headers.Authorization = tokenStore.token
        }
        return config
    },
    (err) => {
        return Promise.reject(err);
    }
)
//导出接口
export default instance;

2.2 引入拦截器

在api文件夹下的接口中以如下方式导入即可:

javascript 复制代码
import request from "@/utils/request.js";

使用如下:

javascript 复制代码
//其它..
export const userRegisterService = () => {
    //其它代码...
    //params为携带的参数
    return request.post('/user/register', params)
}
相关推荐
!win !1 小时前
前端跨标签页通信方案(下)
前端·javascript
f***45321 小时前
基于SpringBoot和PostGIS的各省与地级市空间距离分析
android·前端·后端
编码追梦人2 小时前
从 “手忙脚乱“ 到 “行云流水“:华为云 DevUI 与 MateChat 如何让前端开发飞起来
前端·华为云
用户47949283569152 小时前
TypeScript 简史:它是怎么拯救我的烂代码的
javascript·typescript
S***H2832 小时前
前端动画实现经验,性能优化与兼容性
前端
用户47949283569153 小时前
只有前端 Leader 才会告诉你:那些年踩过的模块加载失败的坑(二)
javascript
xw53 小时前
前端跨标签页通信方案(下)
前端·javascript
zzlyx993 小时前
IoTSharp前端VUE采用npm run build编译提示require() of ES Module 出错
前端·vue.js·npm
全栈技术负责人3 小时前
拒绝“无法复现”:前端全链路日志排查实战手册
前端·全链路·问题排查思路
加洛斯3 小时前
前端小知识003:JS中 == 与 === 的区别
开发语言·前端·javascript