欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 资讯 > Vue-axios工具全局配置请求头信息和拦截器

Vue-axios工具全局配置请求头信息和拦截器

2024/10/25 20:05:15 来源:https://blog.csdn.net/Wgq0731/article/details/143208423  浏览:    关键词:Vue-axios工具全局配置请求头信息和拦截器

全局配置axios可提升代码可维护性,也可以进行统一配置请求头信息和拦截器等

一、创建配置axios的文件

比如我创建的名为:ajax.js文件

二、创建并暴露axios实例配置请求头信息

import axios from 'axios'
//全局配置axios可提升代码可维护性
//创建axios对象,并暴露对象,可以对外部访问
//创建对象时对其进行头信息设置及加载上次携带的cookie
export const ajax=axios.create({headers:{source:'h5','Content_Type':'application/x-www-form-urlencoded'},withCredentials:true //携带cookie
})

source: 'h5':是用来标识请求来源,比如这里表示请求来自 H5 页面。

'Content_Type': 'application/x-www-form-urlencoded':设置请求的内容类型为 application/x-www-form-urlencoded,这是表单数据提交的一种编码类型,表示发送的数据将按照键值对的方式编码。

通过设置 withCredentials: true,确保跨域请求时携带 cookie。这对于需要维护会话状态的前端应用很重要。

三、统一配置拦截器

1、请求拦截器

ajax.interceptors.request.use((req)=>{console.log('请求拦截到了')return req},(err)=>{return Promise.reject(err)}
)

 interceptors是拦截器关键字,request是代表是请求拦截器。第一个参数是正确时执行的函数,第二个是出错时执行的函数。

2、响应拦截器

ajax.interceptors.response.use((resp)=>{console.log('响应拦截到了')return resp
},(err)=>{if(err.response.status==401){alert('未登录,即将跳转至未登录页面')}return Promise.reject(err)
})

跟请求拦截器不同的是interceptors打点调用的是response,代表是响应拦截器。也可以对错误进行一些逻辑判断,如上述代码实现了当状态码是401时弹出提示框提示:未登录。。。。

这样当在别的文件中使用暴露的ajax常量进行发起请求和处理响应了,用ajax发起的请求响应就已经配置好了头信息和拦截器,而不用单独配置。

四、案例:

 onMounted(()=>{//axios用于进行异步提交的工具,可以向服务器发起请求,获取服务端响应的数据ajax.get('https://www.baidu.com').then(resp=>{console.log('返回的结果:',resp)}).catch(err=>{console.log('请求出错:',err)})
})

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com