responseInterceptors.js 1.4 KB
/**
 * 响应拦截
 * @param {Object} http 
 */
import errorCode from "@/common/errorCode.js";
module.exports = (vm) => {
	uni.$u.http.interceptors.response.use((response) => {
		/* 对响应成功做点什么 可使用async await 做异步操作*/
		// console.log(response, "response---------", );
		const data = response.data
		const status = Number(response.statusCode) || 200
		const message = data.reson || errorCode[data.code] || errorCode['default']
		// console.log(data, '相应');
		if (status !== 200 || data.code != '1000') {
			vm.$u.toast(message);
			return Promise.reject(new Error(message))
		}
		return data;
	}, (response) => {
		/*  对响应错误做点什么 (statusCode !== 200)*/
		console.log('相遇错误', response);
		const data = response
		const status = Number(response.statusCode) || 200
		const message = data.reson || errorCode[status] || errorCode['default']
		if (status === 424) {
			vm.$u.toast('令牌过期,请重新登录');
			//清空存储信息
			vm.$u.vuex('vuex_token', '')
			vm.$u.vuex('vuex_refresh_token', '')
			vm.$u.vuex('vuex_username', '')
			vm.$u.vuex('vuex_userId', '')
			vm.$u.vuex('vuex_client_id', '')
			vm.$u.vuex('vuex_user', {})
			setTimeout(() => {
				uni.reLaunch({
					url: '/pages/login/index'
				});
			}, 500);
			return data
		}
		return data;
		// return Promise.reject(response)
	})
}