基于axios给请求添加token

基于axios封装

创建js文件

复制代码
import axios from "axios";
import { baseURL } from '../utils/config.js'     //请求的地址
if (process.env.NODE_ENV === 'development') {
  baseURL;
} else {
  baseURL;
}

//创建自定义axios对象
const instance = axios.create({
  baseURL,
  timeout: 30000,
})


// 增加请求拦截器
instance.interceptors.request.use(
  config => {
    // console.group('本次请求的地址为:', config.url)
    // 给headers添加token属性
    if (sessionStorage.getItem('Token')) {
      config.headers.token = sessionStorage.getItem('Token');
    }
    // alert('解决');
    // alert(JSON.stringify(config))
    // if (store.state.meteoToken) {
    //     config.headers.Authorization = store.state.meteoToken;
    // }
    return config
  },
  error => {
    // loadingCount = 0;
    // if (loadingInstance) {
    //     loadingInstance.close();
    // }
    // alert('这里写警示框弹出的内容');
    return error;
  }
)
//暴露get
export function get (url, params = null) {
  return new Promise((resolve, reject) => {
    instance.get(url, {
      params,
    }).then(res => {
      resolve(res.data);
    }).catch(err => {
      reject(err);
    });
  })
}

//暴露post  
export function post (url, params, isFile = false) {
  let data = params;
  //处理请求头
  let config = {
    Headers: { "Content-Type": "application/json" }
  }

  //处理文件
  if (isFile) {
    data = new FormData();
    for (let i in params) {
      data.append(i, params[i])
    }
    //处理有文件时请求头
    config = {
      Headers: {
        "Content-Type": "multiple/form-data"
      }
    }
  }
  // alert('ewuhshgjsnfsj'); 
  return new Promise((resolve, reject) => {
    instance.post(url, data, config).then(res => {
      resolve(res.data);
    }).catch(err => {
      // alert(err)
      reject(err)
    })
  })
}

封装之后可以直接引用该js文件中的get、post

相关推荐
计算机安禾6 分钟前
【数据结构与算法】第20篇:二叉树的链式存储与四种遍历(前序、中序、后序、层序)
c语言·开发语言·数据结构·c++·学习·算法·visual studio
_MyFavorite_10 分钟前
JAVA重点基础、进阶知识及易错点总结(17)线程安全 & synchronized 同步锁
java·开发语言·安全
_MyFavorite_11 分钟前
JAVA重点基础、进阶知识及易错点总结(13)File 类 + 路径操作
java·开发语言
不会写DN12 分钟前
如何使用PHP创建图像验证码
android·开发语言·php
竹林81814 分钟前
Web3前端开发:使用ethers.js监听智能合约事件
javascript·智能合约
张元清16 分钟前
不用 WebSocket 库,在 React 中构建实时功能
前端·javascript·面试
李白你好16 分钟前
浏览器插件 | 信息收集、统一指纹识别 、DOM XSS 检测 、漏洞报告生成与管理
前端·xss
禾小西23 分钟前
深入理解 Java String:从底层原理到高性能优化实战
java·开发语言·性能优化
渔民小镇28 分钟前
不用前端也能测试 —— 模拟客户端请求模块详解
java·服务器·前端·分布式·游戏
Huangjin007_29 分钟前
【C++类和对象(四)】手撕 Date 类:赋值运算符重载 + 日期计算
开发语言·c++