const install = (Vue, vm) => { Vue.prototype.$u.http.setConfig({ // baseUrl: 'http://2087p773d1.wicp.vip', // 请求的本域名 // baseUrl: 'https://lchighpass.zhieasy.cn', // baseUrl: 'http://speaking.viphk.91tunnel.com',//测试https://speaking.iava.top/ // baseUrl: 'http://89h83e.natappfree.cc',// // baseUrl: 'https://ielts.zhieasy.cn',//正式 baseURL: 'https://api.admin-v2.langsi.online', // baseUrl: 'http://i3qsdb.natappfree.cc',//正式 // baseUrl: 'http://hwihh5.natappfree.cc', // baseUrl: 'http://192.168.10.104:8088', method: 'POST', // 设置为json,返回后会对数据进行一次JSON.parse() dataType: 'json', showLoading: true, // 是否显示请求中的loading loadingText: '雅思备考...', // 请求loading中的文字提示 loadingTime: 800, // 在此时间内,请求还没回来的话,就显示加载中动画,单位ms originalData: false, // 是否在拦截器中返回服务端的原始数据 loadingMask: true, // 展示loading的时候,是否给一个透明的蒙层,防止触摸穿透 // 配置请求头信息 header: { 'content-type': 'application/json;charset=UTF-8', 'Tenant-Id':1 }, }); // 请求拦截部分,如配置,每次请求前都会执行 Vue.prototype.$u.http.interceptor.request = (config) => { // 引用token // 方式一,存放在vuex的token,假设使用了uView封装的vuex方式 // 见:https://uviewui.com/components/globalVariable.html // config.header.token = vm.token; // 方式二,如果没有使用uView封装的vuex方法,那么需要使用$store.state获取 // config.header.token = vm.$store.state.token; // 方式三,如果token放在了globalData,通过getApp().globalData获取 // 方式四,如果token放在了Storage本地存储中,拦截是每次请求都执行的 // 所以哪怕您重新登录修改了Storage,下一次的请求将会是最新值 // const token = uni.getStorageSync('token'); const token = "Bearer b85a1a24553c4f6fa374e18539daf70d" // console.log("我是token", token) config.header.Authorization = token; // #ifdef H5 config.header.Authorization = 'Bearer '+token; // #endif // 可以对某个url进行特别处理,此url参数为this.$u.get(url)中的url值 if(config.url == '/user/login') config.header.noToken = true; // 最后需要将config进行return return config; // 如果return一个false值,则会取消本次请求 // if(config.url == '/user/rest') return false; // 取消某次请求 } // 响应拦截,如配置,每次请求结束都会执行本方法 Vue.prototype.$u.http.interceptor.response = (res) => { // if(res.code == 10022 || res.code == 10023) { // // res为服务端返回值,可能有code,result等字段 // // 这里对res.result进行返回,将会在this.$u.post(url).then(res => {})的then回调中的res的到 // // 如果配置了originalData为true,请留意这里的返回值 // uni.redirectTo({ // url:"/pages/login/login", // fail:function(mes){ // console.log(mes) // }, // success:function(mes){ // console.log(mes) // } // }) // // return res.result; // } if(res.code == 30003) { // res为服务端返回值,可能有code,result等字段 // 这里对res.result进行返回,将会在this.$u.post(url).then(res => {})的then回调中的res的到 // 如果配置了originalData为true,请留意这里的返回值 // return res.result; uni.login({ success: function(ret) { console.log("main.js==>res", ret) vm.$u.post('/user/login',{"js_code": ret.code}).then(res=>{ if (res.code == 10003) { // console.log("新用户登录") uni.setStorageSync('token', res.data); } else if (res.code == 200) { // console.log("老用户登录",res.data) uni.setStorageSync('token', res.data); } }); } }); } return res; // else if(res.code == 201) { // // 假设201为token失效,这里跳转登录 // vm.$u.toast('验证失败,请重新登录'); // setTimeout(() => { // // 此为uView的方法,详见路由相关文档 // vm.$u.route('/pages/user/login') // }, 1500) // return false; // } else { // // 如果返回false,则会调用Promise的reject回调, // // 并将进入this.$u.post(url).then().catch(res=>{})的catch回调中,res为服务端的返回值 // return false; // } } } export default { install }