前端统一api管理

477 阅读2分钟

分享自己在项目中的网络请求的封装

    目的:统一对api进行管理,方便维护。以后在更换请求库的时候可以很快的切换,不影响原来的接口逻辑
    用到的请求库:axios
目录
request.js //对axios进行封装
manage.js  //封装统一方法
api.js     //所有的请求方法
request.js
// 创建 axios 实例  只需一个不用过多创建
const service = axios.create({
  //baseURL: '/jeecg-boot',
  baseURL: apiBaseUrl, // api base_url
  timeout: 90000 // 请求超时时间
})
//请求拦截
service.interceptors.request.use(config => {
  console.log('config',config)
  const token = Vue.ls.get(ACCESS_TOKEN)
  if (token) {
    config.headers['X-Access-Token'] = token // 让每个请求携带自定义 token 请根据实际情况自行修改
  }
  return config
}, (error) => {
  return Promise.reject(error)
})

// response interceptor
//响应拦截
service.interceptors.response.use((response) => {
  console.log('response',response)
  return response.data
}, err)

//错误处理
const err = (error) => {
  if (error.response) {
    let data = error.response.data
    const token = Vue.ls.get(ACCESS_TOKEN)
    console.log("------异常响应------", token)
    console.log("------异常响应------", error.response.status)
    switch (error.response.status) {
      case 403:
        notification.error({ message: '系统提示', description: '拒绝访问', duration: 4 })
        break
      case 500:
        console.log("------error.response------", error.response)
        // update-begin- --- author:liusq ------ date:20200910 ---- for:处理Blob情况----
        let type = error.response.request.responseType;
        if (type === 'blob') {
          //对流文件进行处理
          break;
        }
        // update-end- --- author:liusq ------ date:20200910 ---- for:处理Blob情况----
        //notification.error({ message: '系统提示', description:'Token失效,请重新登录!',duration: 4})
        if (token && data.message.includes("Token失效")) {
          // update-begin- --- author:scott ------ date:20190225 ---- for:Token失效采用弹框模式,不直接跳转----
          // update-end- --- author:scott ------ date:20190225 ---- for:Token失效采用弹框模式,不直接跳转----
        }
        break
      case 404:
        //404处理
        break
      case 504:
        //超时处理
        break
      case 401:
        //未授权处理
        break
      default:
        //默认提示
        break
    }
  }
  return Promise.reject(error)
};
export {
  service as axios
}
manage.js 封装方法
import { axios } from './request'
//post
export function postAction(url,parameter) {
  return axios({
    url: url,
    method:'post' ,
    data: parameter,
    headers: signHeader
  })
}
//put
export function putAction(url,parameter) {
  return axios({
    url: url,
    method:'put',
    data: parameter
  })
}

//get
export function getAction(url,parameter) {
  return axios({
    url: url,
    method: 'get',
    params: parameter,
    headers: signHeader
  })
}

//deleteAction
export function deleteAction(url,parameter) {
  return axios({
    url: url,
    method: 'delete',
    params: parameter
  })
}

api.js 所有请求方法
import { getAction, deleteAction, putAction, postAction} from './manage'

//角色管理
const addRole = (params)=>postAction("/sys/role/add",params);
导出
export {
  addRole,
}
使用
在.vue文件中导入
import {addRole} from './api.js'