【陪诊系统-PC管理端】axios的二次封装

二次封装axios

  1. 引入axios
  2. 创建axios实例,添加配置信息,这里主要设置基础url和请求超时时间
  3. 给上述创建的实例添加拦截器,对请求、响应分别进行拦截
    根据接口文档显示,当登录成功后,每次请求陪诊师、订单信息都需要携带token,所以在后续请求发送前需要在请求头上添加上这个token(token是登录成功后,服务端返回的,然后被存储到本地)
  4. 请求拦截:设置白名单,因为在登录成功前的注册(获取验证码和验证验证码、登录),是不需要携带token的,所以将它排除
  5. 响应拦截:根据返回的响应数据(状态码)进行判断,看看是否数据异常,然后给出相应操作

request.js

javascript 复制代码
import axios from 'axios'
import { ElMessage } from 'element-plus'

const http = axios.create({
    baseURL: 'https:/v3pz.itndedu.com/v3pz',
    timeout: 10000,
    headers: { 'X-Custom-Header': 'foobar' }
});

// 添加拦截器
// 添加请求拦截器
http.interceptors.request.use(function (config) {
    // 在发送请求之前做些什么
    // token作用户鉴权
    const token = localStorage.getItem('pz_token')
    // 不需要添加token的api
    const whiteUrl = ['/get/code', '/user/authentication', '/login']
    if (token && !whiteUrl.includes(config.url)) {
        config.headers['X-token'] = token
    }
    return config;
}, function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
});

// 添加响应拦截器
http.interceptors.response.use(function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    // 对接口异常的数据 给用户提示
    if (response.data.code === -1) {
        ElMessage.warning(response.data.message)
    }
    if (response.data.code === -2) {
        // token错误 清楚缓存
        localStorage.removeItem('pz_token')
        localStorage.removeItem('pz_userInfo')
        localStorage.removeItem('pz_v3pz')
        //window.location.orgin 当前页面路由
        window.location.href = window.location.orgin
    }
    return response;
}, function (error) {
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error);
});

export default http

接口文件

使用二次封装后的axios进行请求,在api.js中定义所有的请求函数,最后到具体的某个地方再调用

javascript 复制代码
import request from '../utils/request'

// 发送验证码
export const getCode = (data) => {
    //发送post请求 data是参数
    return request.post('/get/code', data)
}
// 注册用户
export const UserAuthentication = (data) => {
    return request.post('/user/authentication', data)

}
// 登录
export const login = (data) => {
    return request.post('/login', data)
}
// 权限管理
export const authAdmin = (params) => {
    return request.get('/auth/admin', { params })
}

具体调用

具体某个功能组件中调用api中的对应接口来发送真正的请求,这里在登录界面调用获取验证码请求。

javascript 复制代码
import {getCode,UserAuthentication,login,menuPermissions} from '../../api'

getCode({tel:loginForm.userName}).then((data)=>{
        // console.log('data',data);
        if(data.code === 10000){
            ElMessage.success('发送成功')
        }
    })

文件结构

that's all!

相关推荐
Web极客码7 分钟前
深入了解WordPress网站访客意图
服务器·前端·wordpress
幺风38 分钟前
Claude Code 源码分析 — Tool/MCP/Skill 可扩展工具系统
前端·javascript·ai编程
vjmap1 小时前
唯杰地图CAD图层加高性能特效扩展包发布
前端·gis
ZC跨境爬虫1 小时前
3D 地球卫星轨道可视化平台开发 Day7(AI异步加速+卫星系列精简+AI Agent自动评论)
前端·人工智能·3d·html·json
ID_180079054731 小时前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json
M ? A1 小时前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
vipbic1 小时前
独立开发复盘:我用 Uni-app + Strapi v5 肝了一个“会上瘾”的打卡小程序
前端·微信小程序
IT_陈寒2 小时前
Vite的热更新突然失效,原来是因为这个配置
前端·人工智能·后端
ZC跨境爬虫3 小时前
3D 地球卫星轨道可视化平台开发 Day8(分步渲染200颗卫星+ 前端分页控制)
前端·python·3d·重构·html
竹林8183 小时前
RainbowKit快速集成多链钱包连接,我如何从“连不上”到“丝滑切换”
前端·javascript