Files
shgx_tz_mes_backend_sync/ZR.Vue/src/utils/request.js

141 lines
3.4 KiB
JavaScript
Raw Normal View History

2021-08-23 16:57:25 +08:00
import axios from 'axios'
2021-12-03 17:42:44 +08:00
import {
MessageBox,
Message
} from 'element-ui'
2021-08-23 16:57:25 +08:00
import store from '@/store'
2021-12-03 17:42:44 +08:00
import {
getToken
} from '@/utils/auth'
2021-08-23 16:57:25 +08:00
// import errorCode from '@/utils/errorCode'
// 解决后端跨域获取不到cookie问题
axios.defaults.withCredentials = true
axios.defaults.headers['Content-Type'] = 'application/json'
// 创建axios实例
const service = axios.create({
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_BASE_API,
// 超时
timeout: 30000
})
// request拦截器
service.interceptors.request.use(config => {
// 是否需要设置 token
if (getToken()) {
//将token放到请求头发送给服务器,将tokenkey放在请求头中
2021-12-03 17:42:44 +08:00
config.headers['Authorization'] = 'Bearer ' + getToken();
2021-12-10 18:45:07 +08:00
config.headers['userid'] = store.getters.userId;
2021-08-23 16:57:25 +08:00
} else {
2021-11-28 11:11:34 +08:00
// console.log(config)
2021-08-23 16:57:25 +08:00
}
return config;
}, error => {
console.log(error)
Promise.reject(error)
})
// 响应拦截器
service.interceptors.response.use(res => {
2021-12-03 17:42:44 +08:00
if (res.status !== 200) {
Promise.reject('network error');
return;
2021-08-23 16:57:25 +08:00
}
2021-12-03 17:42:44 +08:00
// 未设置状态码则默认成功状态
2021-12-10 18:45:07 +08:00
const { code, msg } = res.data;
2021-12-03 17:42:44 +08:00
if (code == 401) {
MessageBox.confirm('登录状态已过期,请重新登录', '系统提示', {
confirmButtonText: '重新登录',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
store.dispatch('LogOut').then(() => {
2021-12-04 18:05:20 +08:00
location.href = process.env.VUE_APP_ROUTER_PREFIX + 'index';
2021-12-03 17:42:44 +08:00
})
2021-08-23 16:57:25 +08:00
})
2021-09-29 15:57:56 +08:00
2021-12-04 18:05:20 +08:00
return Promise.reject('无效的会话,或者会话已过期,请重新登录。')
2021-12-03 17:42:44 +08:00
} else if (code == 0 || code == 110 || code == 101 || code == 403 || code == 500) {
Message({
message: msg,
type: 'error'
})
2021-12-04 18:05:20 +08:00
return Promise.reject(msg)
2021-12-03 17:42:44 +08:00
} else {
//返回标准 code/msg/data字段
return res.data;
}
},
2021-08-23 16:57:25 +08:00
error => {
console.log('err' + error)
2021-12-03 17:42:44 +08:00
let {
message
} = error;
2021-08-23 16:57:25 +08:00
if (message == "Network Error") {
message = "后端接口连接异常";
2021-12-03 17:42:44 +08:00
} else if (message.includes("timeout")) {
2021-08-23 16:57:25 +08:00
message = "系统接口请求超时";
2021-12-03 17:42:44 +08:00
} else if (message.includes("Request failed with status code")) {
2021-08-23 16:57:25 +08:00
message = "系统接口" + message.substr(message.length - 3) + "异常";
}
Message({
message: message,
type: 'error',
duration: 5 * 1000
})
return Promise.reject(error)
}
)
/**
* get方法对应get请求
* @param {String} url [请求的url地址]
* @param {Object} params [请求时携带的参数]
*/
export function get(url, params) {
return new Promise((resolve, reject) => {
axios
.get(url, {
params: params
})
.then(res => {
resolve(res.data)
})
.catch(err => {
reject(err)
})
})
}
export function post(url, params) {
return new Promise((resolve, reject) => {
axios
.post(url, {
params: params
})
.then(res => {
resolve(res.data)
})
.catch(err => {
reject(err)
})
})
}
/**
2021-12-03 17:42:44 +08:00
* 提交表单
* @param {*} url
* @param {*} data
*/
2021-08-23 16:57:25 +08:00
export function postForm(url, data, config) {
return new Promise((resolve, reject) => {
axios.post(url, data, config).then(res => {
resolve(res.data)
}).catch(err => {
reject(err)
})
})
}
2021-12-10 18:45:07 +08:00
export default service