import axios from 'axios' import { Notification, MessageBox, Message, Loading } from 'element-ui' import store from '@/store' import { getToken } from '@/utils/auth' import errorCode from '@/utils/errorCode' import { tansParams, blobValidate } from "@/utils/ruoyi"; import { saveAs } from 'file-saver' let downloadLoadingInstance; axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8' // å¯¹åº”å›½é™…åŒ–èµ„æºæ–‡ä»¶åŽç¼€ axios.defaults.headers['Content-Language'] = 'zh_CN' // 创建axios实例 const service = axios.create({ // axiosä¸è¯·æ±‚é…置有baseURL选项,表示请求URL公共部分 baseURL: process.env.VUE_APP_BASE_API, // è¶…æ—¶ timeout: 10000 }) // request拦截器 service.interceptors.request.use(config => { // 是å¦éœ€è¦è®¾ç½® token const isToken = (config.headers || {}).isToken === false if (getToken() && !isToken) { config.headers['Authorization'] = 'Bearer ' + getToken() // 让æ¯ä¸ªè¯·æ±‚æºå¸¦è‡ªå®šä¹‰token è¯·æ ¹æ®å®žé™…情况自行修改 } // getè¯·æ±‚æ˜ å°„params傿•° if (config.method === 'get' && config.params) { let url = config.url + '?' + tansParams(config.params); url = url.slice(0, -1); config.params = {}; config.url = url; } return config }, error => { console.log(error) Promise.reject(error) }) // å“应拦截器 service.interceptors.response.use(res => { // 未设置状æ€ç 则默认æˆåŠŸçŠ¶æ€ const code = res.data.code || 200; // 获å–é”™è¯¯ä¿¡æ¯ const msg = errorCode[code] || res.data.msg || errorCode['default'] // 二进制数æ®åˆ™ç›´æŽ¥è¿”回 if(res.request.responseType === 'blob' || res.request.responseType === 'arraybuffer'){ return res.data } if (code === 401) { MessageBox.confirm('登录状æ€å·²è¿‡æœŸï¼Œæ‚¨å¯ä»¥ç»§ç»ç•™åœ¨è¯¥é¡µé¢ï¼Œæˆ–è€…é‡æ–°ç™»å½•', '系统æç¤º', { confirmButtonText: '釿–°ç™»å½•', cancelButtonText: 'å–æ¶ˆ', type: 'warning' } ).then(() => { store.dispatch('LogOut').then(() => { location.href = process.env.VUE_APP_CONTEXT_PATH + "index"; }) }).catch(() => {}); return Promise.reject('æ— æ•ˆçš„ä¼šè¯ï¼Œæˆ–者会è¯å·²è¿‡æœŸï¼Œè¯·é‡æ–°ç™»å½•。') } else if (code === 500) { Message({ message: msg, type: 'error' }) return Promise.reject(new Error(msg)) } else if (code !== 200) { Notification.error({ title: msg }) return Promise.reject('error') } else { return res.data } }, error => { console.log('err' + error) let { message } = error; if (message == "Network Error") { message = "åŽç«¯æŽ¥å£è¿žæŽ¥å¼‚常"; } else if (message.includes("timeout")) { message = "系统接å£è¯·æ±‚è¶…æ—¶"; } else if (message.includes("Request failed with status code")) { message = "系统接å£" + message.substr(message.length - 3) + "异常"; } Message({ message: message, type: 'error', duration: 5 * 1000 }) return Promise.reject(error) } ) // 通用下载方法 export function download(url, params, filename) { downloadLoadingInstance = Loading.service({ text: "æ£åœ¨ä¸‹è½½æ•°æ®ï¼Œè¯·ç¨å€™", spinner: "el-icon-loading", background: "rgba(0, 0, 0, 0.7)", }) return service.post(url, params, { transformRequest: [(params) => { return tansParams(params) }], headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, responseType: 'blob' }).then(async (data) => { const isLogin = await blobValidate(data); if (isLogin) { const blob = new Blob([data]) saveAs(blob, filename) } else { Message.error('æ— æ•ˆçš„ä¼šè¯ï¼Œæˆ–者会è¯å·²è¿‡æœŸï¼Œè¯·é‡æ–°ç™»å½•。'); } downloadLoadingInstance.close(); }).catch((r) => { console.error(r) Message.error('下载文件出现错误,请è”系管ç†å‘˜ï¼') downloadLoadingInstance.close(); }) } export default service