deming/common/http.interceptor.js

64 lines
2.2 KiB
JavaScript
Raw Normal View History

2020-06-15 02:00:14 +00:00
const install = (Vue, vm) => {
// 此为自定义配置参数,具体参数见上方说明
Vue.prototype.$u.http.setConfig({
2020-06-15 03:34:33 +00:00
baseUrl: 'https://dmmall.sdbairui.com/api',
2020-06-15 02:00:14 +00:00
loadingText: '努力加载中~',
2020-08-05 13:06:29 +00:00
loadingTime: 800,
// originalData: true
2020-06-15 02:00:14 +00:00
});
// 请求拦截配置Token等参数
Vue.prototype.$u.http.interceptor.request = (config) => {
2020-07-21 13:01:42 +00:00
2020-06-15 03:34:33 +00:00
const token = uni.getStorageSync('token');
2020-07-21 13:01:42 +00:00
2020-06-22 09:45:17 +00:00
config.header.Authorization = 'Bearer' + " " + token;
2020-07-21 13:01:42 +00:00
2020-06-15 02:00:14 +00:00
return config;
2020-07-21 13:01:42 +00:00
2020-06-15 02:00:14 +00:00
}
2020-08-05 13:06:29 +00:00
// 响应拦截,如配置,每次请求结束都会执行本方法
Vue.prototype.$u.http.interceptor.response = (res) => {
if(parseInt(res.errCode) == 0) {
// res为服务端返回值可能有errCoderesult等字段
// 这里对res.result进行返回将会在this.$u.post(url).then(res => {})的then回调中的res的到
// 如果配置了originalData为true请留意这里的返回值
return res;
} else if(res.errCode == 401) {
// 假设201为token失效这里跳转登录
2020-08-06 12:42:03 +00:00
// vm.$u.toast('您还没有登录哦,请先去登录!');
if (res.data.action != "memberinfo") {
uni.showModal({
title: "温馨提示",
content: "您还未登录,请立即登录",
cancelText: "以后再说",
confirmText: "立即登录",
confirmColor: "#FF780F",
success(res) {
// console.log(res);
if (res.confirm) {
setTimeout(() => {
// 此为uView的方法详见路由相关文档
vm.$u.route('/pageA/login/login')
}, 500)
}
}
})
}
2020-08-05 13:06:29 +00:00
return false;
2020-08-06 12:42:03 +00:00
} else if (res.errCode == 1) {
console.log(res.message);
2020-08-05 13:06:29 +00:00
} else {
// 如果返回false则会调用Promise的reject回调
// 并将进入this.$u.post(url).then().catch(res=>{})的catch回调中res为服务端的返回值
2020-08-06 09:52:25 +00:00
return res;
2020-08-05 13:06:29 +00:00
}
}
2020-07-21 13:01:42 +00:00
2020-06-15 02:00:14 +00:00
}
export default {
install
}