vue 拦截器

这篇博客介绍了如何在项目中创建一个名为Axios.js的文件,用于封装axios库,设置请求拦截器处理跨域和超时问题,并提供get、post、put等请求方法的快捷调用。同时,配置了axios默认的timeout和Content-Type,以适应不同场景的API请求。
摘要由CSDN通过智能技术生成

第一步 安装 axios

首先在项目文件下新建utils文件夹,在该文件夹下新建文件Axios.js。

import axios from "axios";
axios.interceptors.request.use(
  config => {
    config.withCredentials = true; // 允许携带token ,这个是解决跨域产生的相关问题
    config.timeout = 6000;
    let token = sessionStorage.getItem("csrf-token") || "token";
    if (token) {
      config.headers = {
        "access-token": token
    
      };
    }
    return config;
  },
  error => {
    return Promise.reject(error);
  }
);

axios.interceptors.response.use(
  response => {
    //返回正确做逻辑处理
    return response;
  },
  error => {
    //返回错误做逻辑处理
    return Promise.reject(error);
  }
);
export default axios;

请求方式中使用

import axios from "./Axios";
axios.defaults.timeout = 15000; //超时响应
axios.defaults.headers.post["Content-Type"] =
  "application/x-www-form-urlencoded";
//设置带cookies
axios.defaults.withCredentials = true;

/**
 *
 * pots方法,对应post请求
 * @param {String} url [请求的url地址]
 * @param {Object} params [请求时携带的参数]
 */
export function posts(url, params) {
  return new Promise((resolve, reject) => {
    axios
      .post(url, {
        params: params
      })
      .then(res => {
        resolve(res.data);
      })
      .catch(err => {
        reject(err.data);
      });
  });
}

//axios post请求
export function axiospost(url, data) {
  return new Promise((resolve, reject) => {
    axios({
      method: "post",
      url: url,
      data: data
    }).then(
      response => {
        resolve(response.data);
      },
      err => {
        reject(err);
      }
    );
  });
}
/**
 * get方法,对应get请求
 * @param {String} url [请求的url地址]
 * @param {Object} params [请求时携带的参数]
 */
export function axioget(url, params) {
  return new Promise((resolve, reject) => {
    axios({
      method: "get",
      url: url,
      params: params
    })
      .then(res => {
        resolve(res.data);
      })
      .catch(err => {
        reject(err);
      });
  });
}

/**
 * put方法,对应put请求
 * @param {String} url [请求的url地址]
 * @param {Object} params [请求时携带的参数]
 */
export function axiosput(url, params) {
  return new Promise((resolve, reject) => {
    axios
      .put(url, params)
      .then(res => {
        resolve(res.data);
      })
      .catch(err => {
        reject(err);
      });
  });
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值