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

前端开发 作者: 2024-08-20 21:45:02
一、路由拦截使用 首先在定义路由的时候就需要多添加一个自定义字段requireAuth,用于判断该路由的访问是否需要登录。如果用户已经登录,则顺利进入路由,否则就进入登录页面,路由配置如下: 定义完路
const routes = [
    {
        path: '/',name: '/''repository'true,// 添加该字段,表示进入这个路由是需要登录的
        },component: Repository
    },{
        path: '/login'
router.beforeEach((to,from,next) => {
    if (to.meta.requireAuth) {   判断该路由是否需要登录权限
        if (store.state.token) {   通过vuex state获取当前的token是否存在
            next();
        }
        else {
            next({
                path: '/login' 将跳转的路由path作为参数,登录成功后跳转到该路由
            })
        }
    }
     {
        next();
    }
})
 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
Vue.prototype.$http.interceptors.response.use()
原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_65735.html