Axios代理配置及封装响应拦截处理的方式是什么(axios,开发技术)

时间:2024-05-09 09:25:32 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    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步骤,也就是捕获错误

    代码如下

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

     </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
    本文:Axios代理配置及封装响应拦截处理的方式是什么的详细内容,希望对您有所帮助,信息来源于网络。
    上一篇:Vue.Draggable怎么实现交换位置下一篇:

    9 人围观 / 0 条评论 ↓快速评论↓

    (必须)

    (必须,保密)

    阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18