Vue——axios基本配置及请求拦截

// axios 配置
axios.defaults.timeout = 5000;
axios.defaults.baseURL = 'http://10.0.0.151:8888';

// http request 拦截器
axios.interceptors.request.use(
    config => {
        debugger
        //对于/auth/**的请求路径,默认不添加token认证
        if (config.url.indexOf("/auth") <0 && store.state.token) {
            config.headers.Authorization = `Bearer ${store.state.token}`;
        }
        return config;
    },
    err => {
        return Promise.reject(err);
    });

// http response 拦截器
axios.interceptors.response.use(
    response => {
        return response;
    },
    error => {
        if (error.response) {
            switch (error.response.status) {
                case 401:            /**token未授权或token授权失败,过期等等**/
                    // 401 清除token信息并跳转到登录页面
                    store.commit(types.LOGOUT);
                    routers.replace({
                        path: 'login',
                        query: {redirect: routers.currentRoute.fullPath}
    

你可能感兴趣的:(Vue——axios基本配置及请求拦截)