From 5ecb7958c96d3f0b6d47b79aff7eb306c2cf690f Mon Sep 17 00:00:00 2001 From: charles <981744753@qq.com> Date: 星期二, 06 八月 2024 11:16:58 +0800 Subject: [PATCH] gitlab上面的wms转移到公司git --- src/common/untils/request.js | 79 +++++++++++++++++++++++++++++++++------ 1 files changed, 66 insertions(+), 13 deletions(-) diff --git a/src/common/untils/request.js b/src/common/untils/request.js index 9270bbc..5ddc7a2 100644 --- a/src/common/untils/request.js +++ b/src/common/untils/request.js @@ -1,21 +1,42 @@ import axios from "axios" import { Message } from "element-ui" - -// import router from '@/router' +import {getApsPage} from './index.js'; +// 寮�鍙戠幆澧冧笅灏嗚嚜宸辩殑token澶嶅埗鍒拌繖閲�, 涔熷彲浠ュ湪娴忚鍣ㄤ腑鎵嬪姩娣诲姞token鍒癱ookie涓�,cookie涓殑token浼樺厛 +const DEV_TOKEN = ''; +function environmentType(){ + let type; + if (location.href.includes('192.168.20.119')) { + type = 'test' + } else if (location.href.includes('192.168') || location.href.includes('localhost')) { + type = 'dev' + } else { + type = 'prod' + } + return type +} +const isDev = environmentType() === 'dev'; const Axios = axios.create({ responseType: "json", withCredentials: true // 鏄惁鍏佽甯ookie杩欎簺 -}) +}); /* //POST浼犲弬搴忓垪鍖�(娣诲姞璇锋眰鎷︽埅鍣�) */ Axios.interceptors.request.use( (config) => { - // 鑻ユ槸鏈夊仛閴存潈token , 灏辩粰澶撮儴甯︿笂token - // let token = util.cookies.get("token"); - // if (token != undefined) { - // config.headers.Authorization = "Bearer " + token; - // } + let token = document.cookie.replace( + /(?:(?:^|.*;\s*)token\s*=\s*([^;]*).*$)|^.*$/, + "$1", + ); + if (config.methodType == "down") { + config.responseType = "blob"; + } + if (isDev){ + token = token || DEV_TOKEN + } + if (token) { + config.headers.Authorization = "Bearer " + token; + } return config }, @@ -27,9 +48,32 @@ /* //杩斿洖鐘舵�佸垽鏂�(娣诲姞鍝嶅簲鎷︽埅鍣�) */ Axios.interceptors.response.use( (res) => { - /* //瀵瑰搷搴旀暟鎹仛浜涗簨 */ - if (res.data.code === 200) { + if (res.config.responseType === 'blob') { + return res.data + }else if (res.data.code === 200) { + /* //瀵瑰搷搴旀暟鎹仛浜涗簨 */ return res.data ? res.data : {} + }else if([2012,2013,2014,2015].includes(res.data.code)){ + if (isDev){ + //alert("JWT澶辨晥,鍗冲皢璺宠浆鑷崇櫥褰曢〉..") + window.location = 'http://'+getApsPage()+'/login' + }else { + // JWT閴存潈澶辨晥 璺宠浆鍒扮櫥褰曢〉 + window.location ='http://'+ getApsPage()+'/login' + } + return Promise.reject(res.data) + }else if([2036].includes(res.data.code)){ + if (isDev){ + window.location ='http://'+ getApsPage()+'/commonWeb?resetPwd=true' + }else { + // JWT閴存潈澶辨晥 璺宠浆鍒扮櫥褰曢〉 + window.location ='http://'+ getApsPage()+'/commonWeb?resetPwd=true' + } + + return Promise.reject(res.data) + // if(window.location.pathname && window.location.pathname !== '/login'){ + // window.location = window.location.origin+'/login' + // } } else { Message({ message: res.data.msg, @@ -40,6 +84,16 @@ } }, (error) => { + if (error.response.status === 401){ + if (isDev){ + alert("JWT澶辨晥,鍗冲皢璺宠浆鑷崇櫥褰曢〉..") + window.location ='http://'+ getApsPage()+'/login' + + }else { + // JWT閴存潈澶辨晥 璺宠浆鍒扮櫥褰曢〉 + window.location ='http://'+ getApsPage()+'/login' + } + } let { message } = error if (message === "Network Error") { message = "鍚庣鎺ュ彛杩炴帴寮傚父" @@ -52,9 +106,8 @@ message: message, type: "error", duration: 5 * 1000 - }) + }); return Promise.reject(error) } -) - +); export default Axios -- Gitblit v1.8.0