import axios from "axios";
import router from '@/router/index.js';
import { Message } from "element-ui";
import { getToken, removeToken } from '@/utils/auth'
const service = axios.create({
timeout: 20000 // 请求超时时间
});
// request拦截器,
service.interceptors.request.use(
config => {
// 权限校验
var sysToken = getToken();
if (sysToken && sysToken.length > 0) {
config.headers['Authorization'] = sysToken
}
return config;
},
error => {
return Promise.reject(error);
}
);
// response拦截器,
service.interceptors.response.use(
response => {
if (response.config.responseType === 'blob') {
if (response.status != 200) {
Message.error('请求失败' + response.status);
return Promise.reject()
} else if (!response.headers["content-disposition"]) {
Message.error('暂无接口访问权限');
return Promise.reject()
}
return response
} else {
if (response.data.code !== 0) {
let errMsg = response.data.msg;
if (response.data.code == 401) { // token失效
if (getToken()) {
Message.error(errMsg);
removeToken()
router.replace('/Login')
}
} else {
Message.error(errMsg);
}
return Promise.reject(errMsg)
}
return response.data;
}
},
error => {
Message.error('请求服务器失败');
return Promise.reject(error);
}
);
export default service
axios拦截器通配
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 一、 拦截器介绍 一般在使用axios时,会用到拦截器的功能,一般分为两种:请求拦截器、响应拦截器。 请求拦截器在...
- 1、请求拦截器 请求拦截器的作用是在请求发送前进行一些操作,例如在每个请求体里加上token,统一做了处理如果以后...
- 首先安装axios: 然后创建一个文件夹apiConfig,request.js文件 在配置所有接口的文件,api...
- 缘起 在 Mybatis 执行 like 查询时,如果查询字符包含通配符‘%’或‘_’则查询结果并不是我们预期结果...