const install = (Vue, vm) => { // 此为自定义配置参数,具体参数见上方说明 Vue.prototype.$u.http.setConfig({ baseUrl: 'https://dmmall.sdbairui.com/api', loadingText: '努力加载中~', loadingTime: 800, // originalData: true }); // 请求拦截,配置Token等参数 Vue.prototype.$u.http.interceptor.request = (config) => { const token = uni.getStorageSync('token'); config.header.Authorization = 'Bearer' + " " + token; return config; } // 响应拦截,如配置,每次请求结束都会执行本方法 Vue.prototype.$u.http.interceptor.response = (res) => { if(parseInt(res.errCode) == 0) { // res为服务端返回值,可能有errCode,result等字段 // 这里对res.result进行返回,将会在this.$u.post(url).then(res => {})的then回调中的res的到 // 如果配置了originalData为true,请留意这里的返回值 return res; } else if(res.errCode == 401) { // 假设201为token失效,这里跳转登录 // 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) } if (res.cancel) { } } }) } return false; } else if (res.errCode == 1) { console.log(res.message); return res; } else { // 如果返回false,则会调用Promise的reject回调, // 并将进入this.$u.post(url).then().catch(res=>{})的catch回调中,res为服务端的返回值 return res; } } } export default { install }