import Request from '@/common/luch-request/index.js' import {ACCESS_TOKEN} from '@/common/util/constants.js' import configService from './config.service.js' import tip from '@/common/util/tip.js'; import store from '@/store/index.js'; let apiUrl = configService.apiUrl; const getTokenStorage = () => { let token = '' try{ token = uni.getStorageSync(ACCESS_TOKEN) }catch(e){ //TODO handle the exception console.log("getTokenStorage",token) } return token } const http = new Request() http.setConfig((config) => { /* 设置全局配置 */ config.baseUrl = apiUrl /* 根域名不同 */ config.header = { ...config.header } return config }) /** * 自定义验证器,如果返回true 则进入响应拦截器的响应成功函数(resolve),否则进入响应拦截器的响应错误函数(reject) * @param { Number } statusCode - 请求响应体statusCode(只读) * @return { Boolean } 如果为true,则 resolve, 否则 reject */ // 有默认,非必写 http.validateStatus = (statusCode) => { return statusCode === 200 } http.interceptor.request((config, cancel) => { /* 请求之前拦截器 */ config.header = { ...config.header, 'X-Access-Token':getTokenStorage() } /* if (!token) { // 如果token不存在,调用cancel 会取消本次请求,但是该函数的catch() 仍会执行 cancel('token 不存在') // 接收一个参数,会传给catch((err) => {}) err.errMsg === 'token 不存在' } */ return config }) // 必须使用异步函数,注意 http.interceptor.response(async (response) => { /* 请求之后拦截器 */ // if (response.data.code !== 200) { // 服务端返回的状态码不等于200,则reject() // return Promise.reject(response) // } return response }, (response) => { // 请求错误做点什么 console.log("请求错误做点什么",response); if (response) { let data = response.data const token = uni.getStorageSync(ACCESS_TOKEN) console.log("------异常响应------",token) console.log("------异常响应------",data) switch (data.code) { case 403: tip.error('拒绝访问'); break case 500: if(!token || data.message=="Token失效,请重新登录"){ let timeout=setTimeout(tip.alert('登录已过期'), 1000); store.dispatch('Logout').then(() => { clearTimeout(timeout) window.location.reload() }) } break case 404: break case 504: break case 401: if (token) { let timeout=setTimeout(tip.alert('登录已过期'), 1000); store.dispatch('Logout').then(() => { clearTimeout(timeout) window.location.reload() }) } break default: tip.error({ duration: 0, forbidClick: true, message: data.message }); break } } return response }) const getAction = (url, params) => { return http.get(url, { params }) } const postAction = (url, params) => { return http.post(url, params) } export { http, getAction, postAction }