Vue3 后台框架的网络请求怎么设计?看 XYGo Admin 三套 Axios 实例与拦截器方案

Vue3 后台框架的网络请求怎么设计?看 XYGo Admin 三套 Axios 实例与拦截器方案

做后台管理项目,网络请求层是最容易写乱的地方------Token 混用、接口前缀硬编码、拦截器逻辑散落各处。接手过屎山项目的同学应该都懂。

XYGo Admin 在这方面做了一层很清晰的封装,今天拆开聊聊它的设计思路。

三套请求实例,各司其职

最核心的设计是用 createPrefixedApi(prefix) 工厂函数,按业务域拆出三个独立实例:

typescript 复制代码
// 后台管理接口 --- 自动注入 Bearer Token
export const adminRequest = createPrefixedApi('/admin')

// 前台会员接口 --- 自动注入 Xy-User-Token
export const memberRequest = createPrefixedApi('/member')

// 前台公共接口 --- 无需 Token
export const siteRequest = createPrefixedApi('/site')

这个设计妙在哪?不同域天然隔离,不用每次调接口时手动区分 Token 类型。后台管理员和前台会员使用的是完全不同的认证体系,在一个项目里分开管理远比混在一起安全。

每个实例提供五个标准方法:

方法 说明
adminRequest.get<T>({ url, params?, config? }) GET 请求
adminRequest.post<T>({ url, params?, config? }) POST 请求
adminRequest.put<T>({ url, params?, config? }) PUT 请求
adminRequest.del<T>({ url, params?, config? }) DELETE 请求
adminRequest.request<T>(config) 通用请求

拦截器的自动分流逻辑

请求拦截器做的事情很纯粹------根据 URL 前缀自动选择 Token 注入策略:

  • /admin 开头 → Authorization: Bearer <token>
  • /member 开头 → Xy-User-Token: <token>
  • 其他 → 不注入 Token

响应拦截器对业务码做了分层处理:

  • 0 (success) :直接返回 response.data.data,业务代码不用多解一层
  • -1 (error)ElMessage 提示错误信息
  • 61 (unauthorized):清除 Token + 跳转登录页,带 3 秒防抖避免并发请求反复跳
  • 10010 (kickedOut):弹窗提示被踢下线

防抖跳转登录这个细节挺实用------多个接口同时返回 401 时不会弹出一串登录页。

实际使用:API 层怎么写

封装完后,业务代码里调用就非常干净:

typescript 复制代码
import { adminRequest } from '@/utils/http'

export function fetchDocList(params: any) {
  return adminRequest.get({ url: '/cmsDoc/list', params })
}

export function fetchSaveDoc(data: any) {
  return adminRequest.post({ url: '/cmsDoc/edit', params: data })
}

export function fetchDeleteDoc(id: number) {
  return adminRequest.post({ url: '/cmsDoc/delete', params: { id } })
}

每个 API 文件只负责声明接口,不关心 Token、不关心错误处理,职责单一。

配置项一览

  • baseURL :来自环境变量 VITE_API_URL,切换环境不用改代码
  • 超时:15 秒,够用也不拖沓
  • 失败重试:可配置,默认关闭

总结

XYGo Admin 的网络请求层设计不算花哨,但务实------三实例隔离前后台认证、拦截器自动分流 Token、响应码分层处理,该有的都有。这种封装思路可以直接复用到你自己的 Vue3 后台管理框架 里。对后台管理框架感兴趣的同学,可以去 XYGo Admin 官网看完整的项目结构和代码实现。

相关推荐
浏览器工程师30 分钟前
AI Agent 接浏览器任务,先别让它一路点到底
前端·后端
雨季mo浅忆31 分钟前
VSCode自动格式化三要素
前端
爱勇宝1 小时前
深扒 Anthropic 1680 位工程师简历:应届生几乎没机会,AI 公司最缺的不是博士
前端·后端·程序员
kyriewen2 小时前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
user20585561518134 小时前
Windows 项目安装时报 `node-sass` 错误,如何快速处理
前端
LiaCode4 小时前
Redis 在生产项目的使用
前端·后端
LiaCode4 小时前
一天学完 redis 的爽翻版核心知识总结
前端·后端
大刚测试开发实战4 小时前
如何内网穿透访问本地私有化部署的TestHub
前端·后端·github
风骏时光牛马4 小时前
# Ruby基于Rails框架实现多角色权限管理与数据分页查询完整实战代码案例
前端
weedsfly5 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript