axios封装

本文详细介绍了在Vue.js项目中如何配置和使用axios进行API请求,包括请求和响应的拦截器设置,以及如何根据不同环境调整API请求地址。同时,深入探讨了错误处理策略,确保应用程序在面对各种HTTP状态码时能够给出恰当的反馈。
public html页面
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width,initial-scale=1.0">
    <link rel="icon" href="<%= BASE_URL %>favicon.ico">
    <title>DATAV-DEMO</title>
		<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
		   <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/display.css">
			 <script>
			 	 window.SITE_CONFIG['apiURL'] = '';                      // api请求地址
			 	</script>
			 	<!-- 开发环境 -->
			 	<% if (process.env.VUE_APP_NODE_ENV === 'dev') { %>
			 	  <script>
			 	  window.SITE_CONFIG['apiURL'] = 'http://192.168.0.235:10002';
			 	  // WebSocket地址
			 	 // window.SITE_CONFIG['socketURL'] ='ws://192.168.1.100:81/renren-admin/websocket';
			 	  </script>
			 	<% } %>
			 	<!-- 生产环境 -->
			 	<% if (process.env.VUE_APP_NODE_ENV === 'prod') { %>
			 	  <script>
			 	    window.SITE_CONFIG['apiURL'] = 'http://118.24.91.172:10002';
			 	    // WebSocket地址
			 	   // window.SITE_CONFIG['socketURL'] ='ws://192.168.1.101:81/renren-admin/websocket';
			 	  </script>
			 	<% } %>
  </head>

window.SITE_CONFIG[‘apiURL’] 在request。js中引用

//request.js
/****   request.js   ****/
// 导入axios
import axios from 'axios'
// 使用element-ui Message做消息提醒
import { Message} from 'element-ui';
//1. 创建新的axios实例,
const service = axios.create({
  // 公共接口--这里注意后面会讲
  baseURL:window.SITE_CONFIG['apiURL'],
  // 超时时间 单位是ms,这里设置了3s的超时时间
  timeout: 3 * 1000
})
// 2.请求拦截器
service.interceptors.request.use(config => {
  //发请求前做的一些处理,数据转化,配置请求头,设置token,设置loading等
   // const token = getCookie('名称');注意使用的时候需要引入cookie方法,推荐js-cookie
   config.data = JSON.stringify(config.data);
   config.headers = {
     'Content-Type':'application/x-www-form-urlencoded'
   }
   // if(token){
   //   config.params = {'token':token}
   // }
  return config
}, error => {
  Promise.reject(error)
})

// 3.响应拦截器
service.interceptors.response.use(response => {
  //接收到响应数据并成功后的一些共有的处理,关闭loading等

  return response
}, error => {
   /***** 接收到异常响应的处理开始 *****/
  if (error && error.response) {
    // 1.公共错误处理
    // 2.根据响应码具体处理
    switch (error.response.status) {
      case 400:
        error.message = '错误请求'
        break;
      case 401:
        error.message = '未授权,请重新登录'
        break;
      case 403:
        error.message = '拒绝访问'
        break;
      case 404:
        error.message = '请求错误,未找到该资源'
        window.location.href = "/NotFound"
        break;
      case 405:
        error.message = '请求方法未允许'
        break;
      case 408:
        error.message = '请求超时'
        break;
      case 500:
        error.message = '服务器端出错'
        break;
      case 501:
        error.message = '网络未实现'
        break;
      case 502:
        error.message = '网络错误'
        break;
      case 503:
        error.message = '服务不可用'
        break;
      case 504:
        error.message = '网络超时'
        break;
      case 505:
        error.message = 'http版本不支持该请求'
        break;
      default:
        error.message = `连接错误${error.response.status}`
    }
  } else {
    // 超时处理
    if (JSON.stringify(error).includes('timeout')) {
      Message.error('服务器响应超时,请刷新当前页')
    }
    error.message('连接服务器失败')
  }

  Message.error(err.message)
  /***** 处理结束 *****/
  //如果不需要错误处理,以上的处理过程都可省略
  return Promise.resolve(error.response)
})
//4.导入文件
export default service

调用request.js

/****   http.js   ****/
// 导入封装好的axios实例
import request from './request'

const http ={
    /**
     * methods: 请求
     * @param url 请求地址
     * @param params 请求参数
     */
    get(url,params){
        const config = {
            methods: 'get',
            url:url
        }
        if(params) config.params = params
        return request(config)
    },
    post(url,params){
        const config = {
            methods: 'post',
            url:url
        }
        if(params) config.data = params
        return request(config)
    },
    put(url,params){
        const config = {
            methods: 'put',
            url:url
        }
        if(params) config.params = params
        return request(config)
    },
    delete(url,params){
        const config = {
            methods: 'delete',
            url:url
        }
        if(params) config.params = params
        return request(config)
    }
}
//导出
export default http

方法封装****

import http from '../utils/http'
//
/**
 *  @parms resquest 请求地址 例如:http://197.82.15.15:8088/request/...
 *  @param '/testIp'代表vue-cil中config,index.js中配置的代理
 */
let resquest = "/testIp/request/"

// get请求
export function getListAPI(params){
    return http.get(`${resquest}/getList.json`,params)
}
// post请求
export function postFormAPI(params){
    return http.post(`${resquest}/postForm.json`,params)
}
// put 请求
export function putSomeAPI(params){
    return http.put(`${resquest}/putSome.json`,params)
}
// delete 请求
export function deleteListAPI(params){
    return http.delete(`${resquest}/deleteList.json`,params)
}

//vue页面调用

  import {getListAPI,postFormAPI, putSomeAPI, deleteListAPI} from '../../utils/app'
   export default {
    name: 'DataView',
    components: {
      // cards
    },
    data() {
      return {}
    },
    methods: {
      //request 调用
       //   不传参
             getList() {
               getListAPI().then(res => console.log(res)).catch(err => console.log(err))
             },
       		//传参
             getList(formData) {
               let data = formData
               getListAPI(data).then(res => console.log(res)).catch(err => console.log(err))
             },

             //async await同步调用
             async postForm(formData) {
               const postRes = await postFormAPI(formData)
               const putRes = await putSomeAPI({
                 data: 'putTest'
               })
               const deleteRes = await deleteListAPI(formData.name)
               // 数据处理
               console.log(postRes);
               console.log(putRes);
               console.log(deleteRes);
            }
    }
  }
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值