封装http请求

在utils下的axios中写入

import Vue from 'vue'

import axios from 'axios'

import { getToken, userLoginOut } from './auth'

import router from '../router'

import { baseUrl } from '@/common/env.js'

let vm = new Vue()

const ajax = axios.create({

  baseURL: baseUrl,

  timeout: 30000

})

/** 请求拦截器 **/

ajax.interceptors.request.use(

  config => {

    const token = getToken()

    if (token) {

      config.headers.Authorization = token

    }

    return config

  },

  error => {

    return Promise.reject(error)

  }

)

/** 响应拦截器 **/

ajax.interceptors.response.use(

  response => {

    if (response.data.code === -1) {

      vm.$message({

        message: '登录已过期,请重新登录',

        type: 'error'

      })

      userLoginOut()

      router.push({

        name: 'Login'

      })

      return

    }

    if (response.status === 200) {

      return Promise.resolve(response.data)

    } else {

      return Promise.reject(response.data.message)

    }

  },

  error => {

    return Promise.reject(error)

  }

)

/* 统一封装get请求 */

export const get = (url, params, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'get',

      url,

      params,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

/* 统一封装post请求  */

export const post = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'post',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

/* 统一封装put请求  */

export const put = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'put',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

/* 统一封装delete请求  */

export const deletefn = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'delete',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

// 上传文件

export const upload = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'post',

      url,

      data,

      ...config

    })

      .then(response => {

        console.log(response)

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

// 下载文件

export const downLoad = (url, data, config = { responseType: 'blob' }) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'get',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

=======================================================================

common.js中写入

/************************* 测试环境 ***********************/

const ip = ''

const baseUrl = ip + '/credit' // 本地测试用

/************************* 正式环境 ***********************/

// const ip = '' // 测试服

// const ip = '' // 正式服

// const baseUrl = ip + '/credit'


 

/********************* 图片上传管理 ***********************/

const upload = ip + '/upload/'

const myValidator = {

  regExpPhone: /^1([345789])[0-9]\d{8}$/,

  regExpEmail: /^([A-Za-z0-9_\-.])+@([A-Za-z0-9_\-.])+\.([A-Za-z]{2,4})$/,

  regExpPassword: /.{6,20}$/

}

module.exports = {

  ip,

  baseUrl,

  upload,

  myValidator

}

==================================================================

utils下的auth用于封装存储

export function setToken(val) {

  localStorage.setItem('token', val)

  localStorage.setItem('isLogin', true)

}

==================================================================

最后在api中引入即可

import { get, post, put, downLoad, deletefn } from '@/utils/axios'

// 用户登录

export function login(data) {

  return post('/site/login', data).then(res => {

    return res

  })

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值