当前位置: 首页 > news >正文

vue3 ts 封装axios,配置axios前置拦截器,让所有axios请求携带token

vue3 ts 封装axios,配置axios前置拦截器,让所有axios请求携带token

  • http.ts
  • app.ts
  • vue文件


http.ts

import axios from 'axios' // 引入axios
import router from '@/router'
import Qs from 'qs'
import { ElMessage } from 'element-plus'


const { prefixBasePath } = require('../../../config/basePath')
axios.defaults.baseURL = prefixBasePath;

// 配置axios前置拦截器,作用是让所有axios请求携带token,后台需要token校验是否登录
axios.interceptors.request.use(config => {
  // 1.从缓存中获取到token,这里的Authorization时登录时你给用户设置token的键值
  let authorization = localStorage.getItem("Authorization");
  // 2.如果token不为null,那么设置到请求头中,此处哪怕为null,我们也不进行处理,因为后台会进行拦截
  if (authorization) {
  //后台给登录用户设置的token的键时什么,headers['''']里的键也应该保持一致
    config.headers['Authorization'] = authorization;
  }
  // 3.放行
  return config;
}, error => {
//失败后抛出错误
  Promise.reject(error);
})

//  *   --------------------  get请求  --------------------
// get请求
// 1、根据id查看一条信息
// 2、获取所有数据,展示表格数据
export function getOneOrAllData(url: any, params: any, hideTips: any) {
  return new Promise((resolve, reject) => {
    showLoading()
    axios.get(url, {
      params: params,
      // 解决get传数组问题,主要是以下五行代码
      paramsSerializer: {
        serialize: function (params) {
          return Qs.stringify(params, { arrayFormat: 'repeat' })
        }
      },
    })
      .then(res => {
        hideLoading()
        switch (res.data.code) {
          case 401:
            jumpToLogin()
            break
          case 500:
            ElMessage.error(res.data.message)
            break
          case 200:
            // if (!hideTips)
            //   ElMessage.success(res.data.message)
            resolve(res.data)
            break
          default:
            Toast(res.data.message)
            resolve(res.data)
            break
        }
      })
      .catch(err => {
        errMsg(err)
        reject(err)
      })
  })
}

//  *   --------------------  post请求  --------------------
// (非)formData格式
// 添加、修改
// flag为true,不弹提示窗
export function addOrReviseData(url: any, params: any, showTips: any, hideLoads: any) {
  return new Promise((resolve, reject) => {
    // {
    //   headers: {
    //     'Content-Type': 'multipart/form-data'
    //   }
    // }
    if (!hideLoads)
      showLoading()
    axios.post(url, params)
      .then(res => {
        hideLoading()
        switch (res.data.code) {
          case 401:
            jumpToLogin()
            break
          case 500:
            ElMessage.error(res.data.message)
            resolve(res.data)
            break
          case 200:
            if (showTips)
              ElMessage.success(res.data.message)
            resolve(res.data)
            break
          default:
            resolve(res.data)
            break
        }
      })
      .catch(err => {
        errMsg(err)
        reject(err)
      })
  })
}

//  *   --------------------  登录、退出  --------------------
// 登录 - post
export function logIn(url: any, params: any) {
  return new Promise((resolve, reject) => {
    showLoading()
    axios.post(url, params)
      .then(res => {
        switch (res.data.code) {
          case 500:
            ElMessage.error(res.data.message)
            break
          case 200:
            ElMessage.success(res.data.message)
            resolve(res.data)
            break
        }
      })
      .catch(err => {
        errMsg(err)
        reject(err)
      })
  })
}

// 退出 - get
export function logOut(url: any, params: any) {
  return new Promise((resolve, reject) => {
    axios.get(url, { params: params })
      .then(res => {
        ElMessage.success(res.data.message)
        jumpToLogin(true)
      })
      .catch(err => {
        jumpToLogin(true)
      })
  })
}

// 跳转到登录页
function jumpToLogin(showTips) {
  router.push({ path: '/login' })
}

app.ts

import { getOneOrAllData, addOrReviseData, logIn, logOut} from './http'

// import router from '@/router'
// if (router.app._route.path.includes('/onLineRegister/')) {
//   return '/globalApi/app'
// }
function GlobalUrl() {
  return '/globalApi'
}

export const login = (p: any) => logIn(GlobalUrl() + '/login', p, false)//登录
export const logout = (p: any) => logOut(GlobalUrl() + '/logout', p, false)//退出
export const addOrUpdate = (p: any) => addOrReviseData(GlobalUrl() + '/addOrUpdate', p, true)//增加/修改信息
export const getList = (p: any) => getOneOrAllData(GlobalUrl() + '/getList', p, false)//查询数据

vue文件

import { login } from "@/app"
login(){
	login(form).then((res: any) => {
		console.log(res)
	}
}

相关文章:

  • 使用docker部署springboot、Vue分离项目,部署到主路径
  • Docker技术系列文章,第八篇——Docker 安全基础
  • 华鲲振宇天工TG225 B1国产服务器试装openEuler22.03 -SP4系统
  • LabVIEW多CAN设备连接故障
  • SICAR 标准 KUKA 机器人标准功能块说明手册
  • 激光线检测算法的FPGA实现
  • MyBatis 动态 SQL 优化:标签的实战与技巧
  • u盘文件夹删除没反应的解决办法
  • 语言合成模型Spark-TTS-0.5B学习笔记
  • Java为什么要使用线程池?
  • 【深度学习与实战】2.3、线性回归模型与梯度下降法先导案例--最小二乘法(向量形式求解)
  • 用Python和Stable Diffusion生成AI动画:从图像到视频的全流程指南
  • MYSQL基本语法使用
  • java八股文之JVM
  • 【Mysql】深入理解 MySQL 索引:原理、类型与实践
  • leetcode每日一题:酿造药水需要的最少总时间
  • Ant Design Vue 中的table表格高度塌陷,造成行与行不齐的问题
  • 测试用例生成平台通过大模型升级查询功能,生成智能测试用例
  • 为AI聊天工具添加一个知识系统 之150 设计重审 之15 完整方案及评估 之2
  • 搭建一套正版上门按摩小程序需要具备哪些功能?
  • 事关广大农民利益,农村集体经济组织法5月1日起施行
  • 零食连锁鸣鸣很忙递表港交所:去年营收393亿元,门店超1.4万家,净利润率2.1%
  • 锦江酒店:第一季度营业收入约29.42亿元,境内酒店出租率同比增长
  • 金砖国家外长会晤发表主席声明,强调南方国家合作
  • 普京与卢卡申科举行会晤,将扩大在飞机制造等领域合作
  • 脱发后怎么把头发养回来?脱发自救指南来了