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)
}
相关推荐
颜酱1 分钟前
从 DeepSeek 文本对话到流式输出
前端·javascript·人工智能
Ulyanov18 分钟前
打造现代化雷达电子对抗仿真界面 第二篇:雷达电子对抗仿真系统核心功能实现
前端·python·信息可视化·数据可视化·系统仿真·雷达电子战
鬣主任18 分钟前
重生之我上班学React----360档案篇。
javascript·react.js
快乐小土豆~~20 分钟前
上传视频时截取正脸照片
前端·音视频·vladmandic
276695829230 分钟前
token1005 算法分析
java·前端·javascript·token·token1005·携程酒店·token算法分析
乆夨(jiuze)31 分钟前
记录一个css,实现下划线内容显示,支持文本多行显示
前端·css
GISer_Jing32 分钟前
前端视频多模态:编解码、传输、渲染全链路详解
前端·人工智能·音视频
恋猫de小郭40 分钟前
Flutter PC 多窗口最新进展,底层原生窗口句柄支持已合并
android·前端·flutter
LIO1 小时前
Vue3 + Vite + Pinia + TypeScript 项目完整搭建与实战指南
前端·vue.js
kilito_011 小时前
vue官网例子 讲解2
前端·javascript·vue.js