react 攔截器配置
utils 下 request
import axios from 'axios';
// 環(huán)境變量
let env = process.env.NODE_ENV;
env = 'production';
// development開發(fā) test測試 production生產(chǎn)
let baseUrl = '';
if (env === 'development') {
baseUrl = 'http://localhost:3002';
} else if (env === 'test') {
baseUrl = '待配置';
} else if (env === 'production') {
baseUrl = 'http://huruqing.cn:3002';
}
// 創(chuàng)建axios實(shí)例
const service = axios.create({
// api 的 base_url
baseURL: baseUrl,
timeout: 50000 // 請求超時(shí)時(shí)間(因?yàn)樾枰{(diào)試后臺,所以設(shè)置得比較大)
})
// request攔截器(請求前的處理)
service.interceptors.request.use(
config => {
// if (store.getters.token) {
// config.headers['X-Token'] = getToken() // 讓每個(gè)請求攜帶自定義token 請根據(jù)實(shí)際情況自行修改
// }
return config
},
error => {
// Do something with request error
console.log(error) // for debug
return Promise.reject(error)
}
)
// response 攔截器(數(shù)據(jù)返回后的處理)
service.interceptors.response.use(
response => {
const res = response.data
if (res.code == 666) {
return response.data
} else if (res.code == 603) {
// 跳轉(zhuǎn)到登陸頁面
} else {
return Promise.reject('error')
}
},
error => {
console.log('err' + error) // for debug
return Promise.reject(error)
}
)
const get = (url, data) => {
return service.get(url, {
params: data
});
}
const post = (url, data) => {
return service.get(url, data);
}
export default {
get,
post
}