vue+axios 前端实现的常用拦截

一、路由拦截使用

首先在定义路由的时候就需要多添加一个自定义字段requireAuth,用于判断该路由的访问是否需要登录。如果用户已经登录,则顺利进入路由,否则就进入登录页面,路由配置如下:

const routes = [
    {
        path: '/',name: '/''repository'true,// 添加该字段,表示进入这个路由是需要登录的
        },component: Repository
    },{
        path: '/login'

定义完路由后,我们主要是利用vue-router提供的钩子函数beforeEach()对路由进行判断:

router.beforeEach((to,from,next) => {
    if (to.meta.requireAuth) {   判断该路由是否需要登录权限
        if (store.state.token) {   通过vuex state获取当前的token是否存在
            next();
        }
        else {
            next({
                path: '/login' 将跳转的路由path作为参数,登录成功后跳转到该路由
            })
        }
    }
     {
        next();
    }
})

二、拦截器使用

要想统一处理所有http请求和响应,就得用上 axios 的拦截器。通过配置http response inteceptor,当后端接口返回401 Unauthorized(未授权),让用户重新登录。

 http request 拦截器
axios.interceptors.request.use(
    config => {
         判断是否存在token,如果存在的话,则每个http header都加上token
            config.headers.Authorization = `token ${store.state.token}`;
        }
        return config;
    },err => Promise.reject(err);
    });
 
 http response 拦截器
axios.interceptors.response.use(
    response => response;
    },error =>if (error.response) {
            switch (error.response.status) {
                case 401:
                     返回 401 清除token信息并跳转到登录页面
                    store.commit(types.LOGOUT);
                    router.replace({
                        path: 'login'return Promise.reject(error.response.data)    返回接口返回的错误信息
    });

三、实例

/**
 * http配置
 */
 引入axios以及element ui中的loading和message组件
import axios from 'axios'
import { Loading,Message } from 'element-ui'
 超时时间
axios.defaults.timeout = 5000
 http请求拦截器
var loadinginstace
axios.interceptors.request.use(config => {
  element ui Loading方法
 loadinginstace = Loading.service({ fullscreen: true })
  config
},1)"> {
 loadinginstace.close()
 Message.error({
 message: '加载超时'
 })
  Promise.reject(error)
})
 http响应拦截器
axios.interceptors.response.use(data => { 响应成功关闭loading
 loadinginstace.close()
  data
},1)"> {
 loadinginstace.close()
 Message.error({
 message: '加载失败' Promise.reject(error)
})
 
export default axios

 如果你是使用了vux,那么在main.js这样使用:

Vue.prototype.$http.interceptors.response.use()

 参考地址:vue中axios解决跨域问题和拦截器使用

相关文章

https://segmentfault.com/a/1190000022018995 https://www....
ES6 (ECMAScript 6)中的模块是一个包含 JavaScript 代码的...
from https://mp.weixin.qq.com/s/-rc1lYYlsfx-wR4mQmIIQQ V...
D:\Temp>npm init vite@latest vue3study --temp...
文章浏览阅读1.2k次。最近自己从零撸起的甘特图组件需要子组...
文章浏览阅读3.3k次,点赞3次,收藏16次。静默打印是什么?简...