文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Axios代理配置及封装响应拦截处理的方式是什么

2023-06-29 22:01

关注

今天小编给大家分享一下Axios代理配置及封装响应拦截处理的方式是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

Axios代理配置及响应拦截处理

Axios是vue官方推荐的异步处理方案,所以在几个vue的项目里,都用到了,所以这里写一下Axios的代理配置和响应拦截处理

代理配置

代理主要是为了解决跨域问题,但是现在常规解决跨域的方式,就是让后端配置响应头,使用cors方式跨域前端基本不需要任何处理。

但是有时候后端比较懒,就需要前端通过代理请求完成跨域,其实就是相当于在本地开了一个服务器,通过服务器进行向另一个服务器的代理请求。

但是这样又会产生一定问题,就是再部署到服务器上时,前端项目也必须设置代理,或者直接和后端项目部署同源环境

下面是代理请求的配置:

//config/index.js 文件里module.exports = {     dev{        proxyTable: {          '/': { //将开头为 ‘/'的接口替换            target: 'http://www.hahaha.com/',  //导向这个地址            changeOrigin: true,            ws:true,            pathRewrite: {              '^/': ''    //将开头的斜杠去掉            }          },          '/ws/**': {   //因为项目中用到了websocket 所以这里还配置websocket的代理              target: 'ws://www.hahaha.com',              ws: true,              secure: false,              logLevel: 'debug',          }      }      ...    }   host: '0.0.0.0', //这里顺便一提,把host改成'0.0.0.0‘后可以让局域网内的电脑直接访问项目,默认是localhost    ...}

响应内容拦截处理

因为我们的axios请求响应会将网络请求信息的状态码返回,而通常我们实际运用中不是很需要这样的内容,为了方便我们可以进行统一处理,最后只返回真正的实际内容。

同时我们希望虽然网络请求成功,但是如果请求的内容失败的话,也会流转到catch步骤,也就是捕获错误

代码如下

const http = axios.create({  baseURL: 'api/',  timeout: 20000,});   //创建axios对象//对axios对象响应的拦截处理http.interceptors.response.use((response) => {//进入这里代表请求成功,网络请求状态码是200,但是我们要对请求的内容是否成功进行判断  if (response.data.ErrorCode !== 0) {   //因为我们项目里设定0代表请求成功,所以非零的我们都会直接reject    return Promise.reject(response.data);  }     return Promise.resolve(response.data); //ErrorCode为0的直接返回response.data将网络的状态码直接过滤掉}, (error) => {//进入这里都网络状态码非200的,可能是因为接口错误,也可能是没有token等原因  if(error.constructor.prototype.name == "Error") {  //这里判断返回的是否是错误对象,如果是的说明是网络请求错误    Message({ showClose: true,      message: '网络链接问题或登陆失效!',      type: 'error'})    return new Promise(() => {}) //这里我们可以进行链式异步处理  }  return error.data;//其他请求,说明是因为请求内容错误了,直接返回错误内容});//处理前返回内容{    status: 200    statusText: "OK",    data{        ErrorCode: 0,        token:'xxxx',        name:'xxxx'    }}//处理后返回内容{    ErrorCode: 0,    token:'xxxx',    name:'xxxx'}

Axios的proxy代理配置解析

proxy实际上是一种前端开发中方便开发用的东西,它在本地可以跨域访问其他的网站,但是当页面打包之后,proxy就会失效

我是在vue.config.js中设置proxy的,代码如下

    proxy: {      //匹配到的路径      "/api": {        target: "XXXXXXXXX", //目标主机地址        changeOrigin: true,//是否启动代理        pathRewrite: {    //重写路径          "^/api": ''    //如果遇到前缀为'/api'的url,将它重写为''        }      }    }

举个例子: 

proxy的target设置成http://www.web-jshtml.cn/aaa

如果你想访问http://192.168.1.114:8080/api/,这时候,你碰到了/api,你需要将/api前边的域名转换为target的地址,即

将http://192.168.1.114:8080转换为http://www.web-jshtml.cn/aaa

即是

http://www.web-jshtml.cn/aaa/api/这个地址,但是因为proxy的pathRewrite里需要将'/api'转换为空字符串,所以最终的访问地址是

Axios代理配置及封装响应拦截处理的方式是什么

Axios代理配置及封装响应拦截处理的方式是什么

以上就是“Axios代理配置及封装响应拦截处理的方式是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯