关于vue中axios拦截器的使用

预期目标:解决请求任意接口之前进行统一拦截判断,看是否返回500或404等错误并在页面给出错误提示。

一、刚开始看官方文档,如下:

     

备注:将代码加到页面中发现并未起作用,百度谷歌搜索一番,发现都是千篇一律,不同之处可能就是对返回状态码的处理不一样,并未解决拦截器不起作用的问题。在这期间也尝试了将拦截器单独提出来写出一个http.js然后再将其挂载到vue的原型上,还是不能解决问题。

二、尝试配置全局的baseURL,代码如下:

备注:可以进入拦截器并作出响应,解决了拦截器不起作用的问题,但是这样写又存在另外一个问题,因为我们整个项目的接口配置采用的是创建axios实例的方式,难以实现对每个接口固定ip进行统一配置的操作,如果改动代码的话较为麻烦。

结果:虽然可以拦截,但无法拦截每一个接口的请求,只是拦截了全局配置baseURL

三、为自己创建的axios实例添加拦截器,解决问题

备注:也就是说,官方文档上的axios.interceptors写法,针对的是全局的baseURL,而我们之前没有配置全局的baseURL,一开始检测不到就老是报错,结果配置了全局的好了但是达不到我们的使用要求。

结果:如果说,你采用的是创建实例的方法进行整个api接口的配置管理,那就要用实例名称点interceptors的方式去添加拦截器,而不是axios.interceptors

四、如果想要在响应里面做路由跳转,则需要引入路由配置文件

weixin@zdkeep免费获取各种学习资料面试题及电子书籍,免费进群学习成长技术交流职位内推项目外包等。

  • 14
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 请问您的问题是如何在Vue3使用axios拦截器来添加token吗?如果是这样的话,可以通过以下代码来实现: 首先,在main.js引入axios和设置拦截器: import axios from 'axios'; // 设置baseUrl axios.defaults.baseURL = 'http://localhost:8000/'; // 设置拦截器 axios.interceptors.request.use( config => { const token = localStorage.getItem('token'); if (token) { config.headers.authorization = `Bearer ${token}`; } return config; }, error => { return Promise.reject(error); } ); 然后,您可以在代码使用axios请求,并且该请求会自动带上token: // 发起一个有token的GET请求 axios.get('/api/user').then(response => { console.log(response); }).catch(error => { console.log(error); }); ### 回答2: 在Vue3使用axios拦截器来为每个HTTP请求设置token是一种常见实践。Axios拦截器可以帮助我们在请求发送之前或响应返回之前拦截,并在拦截器添加必要的数据,如token。为了在Vue3使用Axios拦截器为每个HTTP请求设置token,下面的内容将提供一些具体方法。 首先,我们需要安装AxiosVue3,安装方法为: ```vue3 # 安装vue3 npm i vue@next -S # 安装axios npm i axios -S ``` 然后,我们需要在Vue3应用创建一个Axios实例,代码如下: ```vue3 import axios from 'axios'; const api = axios.create({ baseURL: 'http://localhost:3000', }); export default api; ``` 在应用程序,我们可以在需要发送HTTP请求的组件导入并使用此api实例。 接下来,我们需要在Axios实例创建一个拦截器拦截器拦截HTTP请求并在其添加必要的headers。在这里,我们添加一个头部,它包含一个名为“Authorization”的令牌。代码如下: ```vue3 api.interceptors.request.use((config) => { config.headers.Authorization = 'Bearer ' + localStorage.getItem('token'); return config; }); ``` 通过使用这个拦截器,我们可以在每个HTTP请求自动添加一个名为“Authorization”的头部,它包含了从localStorage获取的令牌。 在这里,我们还要考虑到token可能会过期,因此我们还可以添加一个拦截器检查HTTP响应。如果响应包含401状态码,我们会强制用户重新登录以获取新的token。代码如下: ```vue3 api.interceptors.response.use( response => response, error => { if (error.response.status === 401) { localStorage.removeItem('token'); router.push('/login'); } return Promise.reject(error); }); ``` 在这个拦截器,我们首先检查响应是否包含401状态码。如果是,我们清除localStorage的token并强制用户重新登录。 总之,Vue3使用Axios拦截器为每个HTTP请求设置token是一种常见实践,并且可以非常轻松地实现。借助Axios拦截器,我们可以自动为每个HTTP请求设置token,并在token过期时强制用户重新登录。 ### 回答3: 在Vue3使用Axios拦截器使用token进行身份验证是一种非常常见的做法。以下是详细的步骤: 第一步:安装AxiosVue-Router 安装AxiosVue-Router: ``` npm install axios vue-router --save ``` 该命令会将axiosvue-router安装到项目。 第二步:创建Axios实例和拦截器 创建一个名为axios.js的新文件,并在其添加以下代码: ```javascript import axios from "axios"; import router from "@/router"; const axiosInstance = axios.create({ baseURL: process.env.VUE_APP_API_BASE_URL }); axiosInstance.interceptors.request.use(config => { const token = localStorage.getItem("token"); if (token) { config.headers["Authorization"] = `Bearer ${token}`; } return config; }, error => { return Promise.reject(error); }); axiosInstance.interceptors.response.use(response => { return response; }, error => { if (error.response.status === 401) { router.push("/login"); } return Promise.reject(error); }); export default axiosInstance; ``` 在这里,我们创建了一个Axios实例,并在请求添加了一个拦截器来检查本地存储是否有token。如果存在,则将其添加到请求头。此外,我们还添加了一个拦截器来处理401未授权错误响应,并重定向到登录页面。 第三步:在Vue组件使用Axios实例 确保我们在请求数据时始终使用我们创建的Axios实例。为此,我们需要在组件导入该实例: ```javascript import axiosInstance from "@/axios"; ``` 我们现在可以像这样在组件使用Axios: ```javascript axiosInstance.get("/users") .then(response => { console.log(response); }) .catch(error => { console.log(error); }); ``` 现在,我们已经成功地设置了Axios拦截器使用token进行身份验证。我们可以在Axios实例添加其他拦截器,以满足特定的需求。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值