Axios二次封装 并使用

// 环境的切换

if (process.env.NODE_ENV == 'development') {

    axios.defaults.baseURL = '/api';

} else if (process.env.NODE_ENV == 'debug') {

    axios.defaults.baseURL = ‘/‘dev;

} else if (process.env.NODE_ENV == 'production') {

    axios.defaults.baseURL = 'http://api.123dailu.com/';

}

// 请求超时时间

axios.defaults.timeout = 10000;

// 请求拦截器

axios.interceptors.request.use(

    config => {

        // 每次发送请求之前判断是否存在token,如果存在,则统一在http请求的header都加上token,不用每次请求都手动添加了

        // 即使本地存在token,也有可能token是过期的,所以在响应拦截器中要对返回状态进行判断

        const token = store.state.token;

        token && (config.headers.Authorization = token);

        return config;

    },

    error => {

        return Promise.error(error);

    })

// 响应拦截器

axios.interceptors.response.use(

    response => {

        if (response.status === 200) {

            return Promise.resolve(response);

        } else {

            return Promise.reject(response);

        }

    },

    // 服务器状态码不是200的情况

    error => {

        if (error.response.status) {

            switch (error.response.status) {

                // 401: 未登录    

                // 未登录则跳转登录页面,并携带当前页面的路径    

                // 在登录成功后返回当前页面,这一步需要在登录页操作。    

                case 401:

                    router.replace({

                        path: '/login',

                        query: { redirect: router.currentRoute.fullPath }

                    });

                    break;

                // 403 token过期    

                // 登录过期对用户进行提示    

                // 清除本地token和清空vuex中token对象    

                // 跳转登录页面    

                case 403:

                    Toast({

                        message: '登录过期,请重新登录',

                        duration: 1000,

                        forbidClick: true

                    });

                    // 清除token     

                    localStorage.removeItem('token');

                    store.commit('loginSuccess', null);

                    // 跳转登录页面,并将要浏览的页面fullPath传过去,登录成功后跳转需要访问的页面

                    setTimeout(() => {

                        router.replace({

                            path: '/login',

                            query: {

                                redirect: router.currentRoute.fullPath

                            }

                        });

                    }, 1000);

                    break;

                // 404请求不存在    

                case 404:

                    Toast({

                        message: '网络请求不存在',

                        duration: 1500,

                        forbidClick: true

                    });

                    break;

                // 其他错误,直接抛出错误提示    

                default:

                    Toast({

                        message: error.response.data.message,

                        duration: 1500,

                        forbidClick: true

                    });

            }

            return Promise.reject(error.response);

        }

    }

);

/**

* get方法,对应get请求

* @param {String} url [请求的url地址]

* @param {Object} params [请求时携带的参数]

*/

export function get(url, params) {

    return new Promise((resolve, reject) => {

        axios.get(url, {

            params: params

        })

            .then(res => {

                resolve(res.data);

            })

            .catch(err => {

                reject(err.data)

            })

    });

}

/**

* post方法,对应post请求

* @param {String} url [请求的url地址]

* @param {Object} params [请求时携带的参数]

*/

export function post(url, params) {

    return new Promise((resolve, reject) => {

        axios.post(url, QS.stringify(params))

            .then(res => {

                resolve(res.data);

            })

            .catch(err => {

                reject(err.data)

            })

    });

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值