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)
}
相关推荐
青柠代码录几秒前
【Vite】vite.config.ts 配置详解(Vite 8)
vue.js
字节跳动的猫3 分钟前
2026 四款 AI:开发场景适配全面解析
前端·人工智能·开源
gyx_这个杀手不太冷静14 分钟前
大人工智能时代下前端界面全新开发模式的思考(四)
前端·架构·ai编程
Ruihong25 分钟前
你的 Vue 3 useAttrs(),VuReact 会编译成什么样的 React?
vue.js·react.js·面试
时寒的笔记28 分钟前
js逆向_webpack讲解加载器&酷某音乐案例
开发语言·javascript·webpack
李剑一36 分钟前
我做了个微信聊天模拟器,已开源
前端
yusirxiaer44 分钟前
为什么 markRaw 能修复 Vue 3 + ECharts 的 resize 报错
javascript·vue.js·echarts
代码搬运媛1 小时前
30分钟带你从0手搓一个AI-Cli命令行工具
前端
赛博切图仔1 小时前
前端性能内卷终点?Signals 正在重塑我们的开发习惯
前端·javascript·vue.js
小江的记录本1 小时前
【RAG】RAG检索增强生成(核心架构、全流程、RAG优化方案、常见问题与解决方案)
java·前端·人工智能·后端·python·机器学习·架构