|  |  | @ -1,110 +1,132 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  | import axios from 'axios' |  |  |  | import axios from "axios"; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | import {Notification, MessageBox, Message, Loading} from 'element-ui' |  |  |  | import { Notification, MessageBox, Message, Loading } from "element-ui"; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | import store from '@/store' |  |  |  | import store from "@/store"; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | import {getAdminId, getToken} from '@/utils/auth' |  |  |  | import { getAdminId, getToken } from "@/utils/auth"; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | import errorCode from '@/utils/errorCode' |  |  |  | import errorCode from "@/utils/errorCode"; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | import {tansParams, blobValidate} from "@/utils/ruoyi"; |  |  |  | import { tansParams, blobValidate } from "@/utils/ruoyi"; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | import cache from '@/plugins/cache' |  |  |  | import cache from "@/plugins/cache"; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | import {saveAs} from 'file-saver' |  |  |  | import { saveAs } from "file-saver"; | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | let downloadLoadingInstance; |  |  |  | let downloadLoadingInstance; | 
			
		
	
		
		
			
				
					
					|  |  |  | // 是否显示重新登录
 |  |  |  | // 是否显示重新登录
 | 
			
		
	
		
		
			
				
					
					|  |  |  | export let isRelogin = {show: false}; |  |  |  | export let isRelogin = { show: false }; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8' |  |  |  | axios.defaults.headers["Content-Type"] = "application/json;charset=utf-8"; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | // 对应国际化资源文件后缀
 |  |  |  | // 对应国际化资源文件后缀
 | 
			
		
	
		
		
			
				
					
					|  |  |  | axios.defaults.headers['Content-Language'] = 'zh_CN' |  |  |  | axios.defaults.headers["Content-Language"] = "zh_CN"; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | // 创建axios实例
 |  |  |  | // 创建axios实例
 | 
			
		
	
		
		
			
				
					
					|  |  |  | const service = axios.create({ |  |  |  | const service = axios.create({ | 
			
		
	
		
		
			
				
					
					|  |  |  |   // axios中请求配置有baseURL选项,表示请求URL公共部分
 |  |  |  |   // axios中请求配置有baseURL选项,表示请求URL公共部分
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   baseURL: process.env.VUE_APP_BASE_API, |  |  |  |   baseURL: process.env.VUE_APP_BASE_API, | 
			
		
	
		
		
			
				
					
					|  |  |  |   // 超时
 |  |  |  |   // 超时
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   timeout: 10000 |  |  |  |   timeout: 10000, | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | }) |  |  |  | }); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | // request拦截器
 |  |  |  | // request拦截器
 | 
			
		
	
		
		
			
				
					
					|  |  |  | service.interceptors.request.use(config => { |  |  |  | service.interceptors.request.use( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   (config) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |     // 是否需要设置 token
 |  |  |  |     // 是否需要设置 token
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   const isToken = (config.headers || {}).isToken === false |  |  |  |     const isToken = (config.headers || {}).isToken === false; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     // 是否需要防止数据重复提交
 |  |  |  |     // 是否需要防止数据重复提交
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   const isRepeatSubmit = (config.headers || {}).repeatSubmit === false |  |  |  |     const isRepeatSubmit = (config.headers || {}).repeatSubmit === false; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     if (getToken() && !isToken) { |  |  |  |     if (getToken() && !isToken) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       // config.headers['ADMIN_TOKEN'] = getToken() // 让每个请求携带自定义token 请根据实际情况自行修改
 |  |  |  |       // config.headers['ADMIN_TOKEN'] = getToken() // 让每个请求携带自定义token 请根据实际情况自行修改
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       config.headers = { |  |  |  |       config.headers = { | 
			
		
	
		
		
			
				
					
					|  |  |  |         ADMIN_ID: getAdminId(), |  |  |  |         ADMIN_ID: getAdminId(), | 
			
		
	
		
		
			
				
					
					|  |  |  |       ADMIN_TOKEN: getToken() |  |  |  |         ADMIN_TOKEN: getToken(), | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       }; |  |  |  |       }; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     // get请求映射params参数
 |  |  |  |     // get请求映射params参数
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   if (config.method === 'get' && config.params) { |  |  |  |     if (config.method === "get" && config.params) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     let url = config.url + '?' + tansParams(config.params); |  |  |  |       let url = config.url + "?" + tansParams(config.params); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       url = url.slice(0, -1); |  |  |  |       url = url.slice(0, -1); | 
			
		
	
		
		
			
				
					
					|  |  |  |       config.params = {}; |  |  |  |       config.params = {}; | 
			
		
	
		
		
			
				
					
					|  |  |  |       config.url = url; |  |  |  |       config.url = url; | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   if (!isRepeatSubmit && (config.method === 'post' || config.method === 'put')) { |  |  |  |     if ( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       !isRepeatSubmit && | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       (config.method === "post" || config.method === "put") | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       const requestObj = { |  |  |  |       const requestObj = { | 
			
		
	
		
		
			
				
					
					|  |  |  |         url: config.url, |  |  |  |         url: config.url, | 
			
		
	
		
		
			
				
					
					|  |  |  |       data: typeof config.data === 'object' ? JSON.stringify(config.data) : config.data, |  |  |  |         data: | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       time: new Date().getTime() |  |  |  |           typeof config.data === "object" | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |             ? JSON.stringify(config.data) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     const sessionObj = cache.session.getJSON('sessionObj') |  |  |  |             : config.data, | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     if (sessionObj === undefined || sessionObj === null || sessionObj === '') { |  |  |  |         time: new Date().getTime(), | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       cache.session.setJSON('sessionObj', requestObj) |  |  |  |       }; | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       const sessionObj = cache.session.getJSON("sessionObj"); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       if ( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         sessionObj === undefined || | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         sessionObj === null || | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         sessionObj === "" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       ) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         cache.session.setJSON("sessionObj", requestObj); | 
			
		
	
		
		
			
				
					
					|  |  |  |       } else { |  |  |  |       } else { | 
			
		
	
		
		
			
				
					
					|  |  |  |         const s_url = sessionObj.url; // 请求地址
 |  |  |  |         const s_url = sessionObj.url; // 请求地址
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         const s_data = sessionObj.data; // 请求数据
 |  |  |  |         const s_data = sessionObj.data; // 请求数据
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         const s_time = sessionObj.time; // 请求时间
 |  |  |  |         const s_time = sessionObj.time; // 请求时间
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         const interval = 1000; // 间隔时间(ms),小于此时间视为重复提交
 |  |  |  |         const interval = 1000; // 间隔时间(ms),小于此时间视为重复提交
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       if (s_data === requestObj.data && requestObj.time - s_time < interval && s_url === requestObj.url) { |  |  |  |         if ( | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         const message = '数据正在处理,请勿重复提交'; |  |  |  |           s_data === requestObj.data && | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         console.warn(`[${s_url}]: ` + message) |  |  |  |           requestObj.time - s_time < interval && | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         return Promise.reject(new Error(message)) |  |  |  |           s_url === requestObj.url | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         ) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           const message = "数据正在处理,请勿重复提交"; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           console.warn(`[${s_url}]: ` + message); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           return Promise.reject(new Error(message)); | 
			
		
	
		
		
			
				
					
					|  |  |  |         } else { |  |  |  |         } else { | 
			
		
	
		
		
			
				
					
					|  |  |  |         cache.session.setJSON('sessionObj', requestObj) |  |  |  |           cache.session.setJSON("sessionObj", requestObj); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |       } |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     return config; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   }, | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   (error) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     console.log("2", error); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     Promise.reject(error); | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |   return config |  |  |  | ); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | }, error => { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   console.log(error) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   Promise.reject(error) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | }) |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | // 响应拦截器
 |  |  |  | // 响应拦截器
 | 
			
		
	
		
		
			
				
					
					|  |  |  | service.interceptors.response.use(res => { |  |  |  | service.interceptors.response.use( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   (res) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |     // 未设置状态码则默认成功状态
 |  |  |  |     // 未设置状态码则默认成功状态
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     const code = res.data.code || 200; |  |  |  |     const code = res.data.code || 200; | 
			
		
	
		
		
			
				
					
					|  |  |  |     // 获取错误信息
 |  |  |  |     // 获取错误信息
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     const msg = errorCode[code] || res.data.message |  |  |  |     const msg = errorCode[code] || res.data.message; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     // 二进制数据则直接返回
 |  |  |  |     // 二进制数据则直接返回
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (res.request.responseType === 'blob' || res.request.responseType === 'arraybuffer') { |  |  |  |     if ( | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       return res.data |  |  |  |       res.request.responseType === "blob" || | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       res.request.responseType === "arraybuffer" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       return res.data; | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (code === 2) { |  |  |  |     if (code === 2) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       if (!isRelogin.show) { |  |  |  |       if (!isRelogin.show) { | 
			
		
	
		
		
			
				
					
					|  |  |  |         isRelogin.show = true; |  |  |  |         isRelogin.show = true; | 
			
		
	
		
		
			
				
					
					|  |  |  |         MessageBox.confirm('登录状态已过期,您可以继续留在该页面,或者重新登录', '系统提示', { |  |  |  |         MessageBox.confirm( | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             confirmButtonText: '重新登录', |  |  |  |           "登录状态已过期,您可以继续留在该页面,或者重新登录", | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             cancelButtonText: '取消', |  |  |  |           "系统提示", | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             type: 'warning' |  |  |  |           { | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             confirmButtonText: "重新登录", | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             cancelButtonText: "取消", | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             type: "warning", | 
			
		
	
		
		
			
				
					
					|  |  |  |           } |  |  |  |           } | 
			
		
	
		
		
			
				
					
					|  |  |  |         ).then(() => { |  |  |  |         ) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           .then(() => { | 
			
		
	
		
		
			
				
					
					|  |  |  |             isRelogin.show = false; |  |  |  |             isRelogin.show = false; | 
			
		
	
		
		
			
				
					
					|  |  |  |           store.dispatch('LogOut').then(() => { |  |  |  |             store.dispatch("LogOut").then(() => { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |               location.href = process.env.VUE_APP_CONTEXT_PATH; |  |  |  |               location.href = process.env.VUE_APP_CONTEXT_PATH; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             }); | 
			
		
	
		
		
			
				
					
					|  |  |  |           }) |  |  |  |           }) | 
			
		
	
		
		
			
				
					
					|  |  |  |         }).catch(() => { |  |  |  |           .catch(() => { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             isRelogin.show = false; |  |  |  |             isRelogin.show = false; | 
			
		
	
		
		
			
				
					
					|  |  |  |           }); |  |  |  |           }); | 
			
		
	
		
		
			
				
					
					|  |  |  |       } |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |       return Promise.reject('无效的会话,或者会话已过期,请重新登录。') |  |  |  |       return Promise.reject("无效的会话,或者会话已过期,请重新登录。"); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     }else { |  |  |  |     } else { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       return res.data |  |  |  |       return res.data; | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   }, |  |  |  |   }, | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -124,9 +146,9 @@ service.interceptors.response.use(res => { | 
			
		
	
		
		
			
				
					
					|  |  |  |       return Promise.reject('error') |  |  |  |       return Promise.reject('error') | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |    */ |  |  |  |    */ | 
			
		
	
		
		
			
				
					
					|  |  |  |   error => { |  |  |  |   (error) => { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     console.log('err' + error) |  |  |  |     console.log("err" + error); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     let {message} = error; |  |  |  |     let { message } = error; | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     if (message == "Network Error") { |  |  |  |     if (message == "Network Error") { | 
			
		
	
		
		
			
				
					
					|  |  |  |       message = "后端接口连接异常"; |  |  |  |       message = "后端接口连接异常"; | 
			
		
	
		
		
			
				
					
					|  |  |  |     } else if (message.includes("timeout")) { |  |  |  |     } else if (message.includes("timeout")) { | 
			
		
	
	
		
		
			
				
					|  |  | @ -136,12 +158,12 @@ service.interceptors.response.use(res => { | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     Message({ |  |  |  |     Message({ | 
			
		
	
		
		
			
				
					
					|  |  |  |       message: message, |  |  |  |       message: message, | 
			
		
	
		
		
			
				
					
					|  |  |  |       type: 'error', |  |  |  |       type: "error", | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       duration: 5 * 1000 |  |  |  |       duration: 5 * 1000, | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     }) |  |  |  |     }); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     return Promise.reject(error) |  |  |  |     return Promise.reject(error); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | ) |  |  |  | ); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | // 通用下载方法
 |  |  |  | // 通用下载方法
 | 
			
		
	
		
		
			
				
					
					|  |  |  | export function download(url, params, filename) { |  |  |  | export function download(url, params, filename) { | 
			
		
	
	
		
		
			
				
					|  |  | @ -149,30 +171,36 @@ export function download(url, params, filename) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     text: "正在下载数据,请稍候", |  |  |  |     text: "正在下载数据,请稍候", | 
			
		
	
		
		
			
				
					
					|  |  |  |     spinner: "el-icon-loading", |  |  |  |     spinner: "el-icon-loading", | 
			
		
	
		
		
			
				
					
					|  |  |  |     background: "rgba(0, 0, 0, 0.7)", |  |  |  |     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", | 
			
		
	
		
		
			
				
					
					|  |  |  |     }) |  |  |  |     }) | 
			
		
	
		
		
			
				
					
					|  |  |  |   return service.post(url, params, { |  |  |  |     .then(async (data) => { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     transformRequest: [(params) => { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       return tansParams(params) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     }], |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     headers: {'Content-Type': 'application/x-www-form-urlencoded'}, |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     responseType: 'blob' |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   }).then(async (data) => { |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       const isLogin = await blobValidate(data); |  |  |  |       const isLogin = await blobValidate(data); | 
			
		
	
		
		
			
				
					
					|  |  |  |       if (isLogin) { |  |  |  |       if (isLogin) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       const blob = new Blob([data]) |  |  |  |         const blob = new Blob([data]); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       saveAs(blob, filename) |  |  |  |         saveAs(blob, filename); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       } else { |  |  |  |       } else { | 
			
		
	
		
		
			
				
					
					|  |  |  |         const resText = await data.text(); |  |  |  |         const resText = await data.text(); | 
			
		
	
		
		
			
				
					
					|  |  |  |         const rspObj = JSON.parse(resText); |  |  |  |         const rspObj = JSON.parse(resText); | 
			
		
	
		
		
			
				
					
					|  |  |  |       const errMsg = errorCode[rspObj.code] || rspObj.msg || errorCode['default'] |  |  |  |         const errMsg = | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           errorCode[rspObj.code] || rspObj.msg || errorCode["default"]; | 
			
		
	
		
		
			
				
					
					|  |  |  |         Message.error(errMsg); |  |  |  |         Message.error(errMsg); | 
			
		
	
		
		
			
				
					
					|  |  |  |       } |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |       downloadLoadingInstance.close(); |  |  |  |       downloadLoadingInstance.close(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   }).catch((r) => { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     console.error(r) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     Message.error('下载文件出现错误,请联系管理员!') |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     downloadLoadingInstance.close(); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     }) |  |  |  |     }) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     .catch((r) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       console.error(r); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       Message.error("下载文件出现错误,请联系管理员!"); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       downloadLoadingInstance.close(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     }); | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | export default service |  |  |  | export default service; | 
			
				
				
			
		
	
		
		
	
	
		
		
			
				
					|  |  | 
 |