96 lines
3.1 KiB
JavaScript
96 lines
3.1 KiB
JavaScript
import axios from 'axios';
|
||
import QS from 'qs';
|
||
import { goTologin } from '@/utils/util.js'
|
||
import { showFullScreenLoading, tryHideFullScreenLoading } from './loading'
|
||
import store from '@/store/index';
|
||
|
||
axios.defaults.baseURL = 'https://app.gter.net'
|
||
// axios.defaults.baseURL = '/index'
|
||
axios.defaults.emulateJSON = true
|
||
axios.defaults.withCredentials = true
|
||
|
||
axios.interceptors.request.use( //响应拦截
|
||
async config => {
|
||
if (config.url != '/tenement/pc/api/user/operation') showFullScreenLoading()
|
||
// 开发时登录用的,可以直接替换小程序的 authorization
|
||
// if (process.env.NODE_ENV == "development") config['headers']['authorization'] = "x2mmnl9grt51bpplj2k6ioiuummzhnw3"
|
||
if (process.env.NODE_ENV == "development") config['headers']['authorization'] = "gifqtoiomgb2efu7tcr16kcgs2"
|
||
return config;
|
||
},
|
||
error => {
|
||
return Promise.error(error);
|
||
})
|
||
// 响应拦截器
|
||
axios.interceptors.response.use(
|
||
response => {
|
||
tryHideFullScreenLoading()
|
||
if (response.status === 200) return Promise.resolve(response); //进行中
|
||
else return Promise.reject(response); //失败
|
||
},
|
||
// 服务器状态码不是200的情况
|
||
error => {
|
||
tryHideFullScreenLoading()
|
||
if (error.response.status) {
|
||
switch (error.response.status) {
|
||
// 401: 未登录
|
||
case 401:
|
||
// goTologin() // 跳转登录页面
|
||
store.state.showloginmodal = true
|
||
break
|
||
case 403:
|
||
// router.push('/login')
|
||
break
|
||
// 404请求不存在
|
||
case 404:
|
||
break;
|
||
// 其他错误,直接抛出错误提示
|
||
default:
|
||
}
|
||
return Promise.reject(error.response);
|
||
}
|
||
}
|
||
);
|
||
/**
|
||
* get方法,对应get请求
|
||
* @param {String} url [请求的url地址]
|
||
* @param {Object} params [请求时携带的参数]
|
||
*/
|
||
const $get = (url, params) => {
|
||
return new Promise((resolve, reject) => {
|
||
axios.get(url, {
|
||
params: params,
|
||
}).then(res => {
|
||
resolve(res.data);
|
||
}).catch(err => {
|
||
reject(err.data)
|
||
})
|
||
});
|
||
}
|
||
/**
|
||
* post方法,对应post请求
|
||
* @param {String} url [请求的url地址]
|
||
* @param {Object} params [请求时携带的参数]
|
||
*/
|
||
const $post = (url, params) => {
|
||
return new Promise((resolve, reject) => {
|
||
//是将对象 序列化成URL的形式,以&进行拼接
|
||
axios.post(url, QS.stringify(params)).then(res => {
|
||
resolve(res.data);
|
||
}).catch(err => {
|
||
if (err.data.code == 401) {
|
||
resolve(err.data);
|
||
} else reject(err.data)
|
||
|
||
})
|
||
});
|
||
}
|
||
//下面是vue3必须加的,vue2不需要,只需要暴露出去get,post方法就可以
|
||
export default {
|
||
get: $get,
|
||
post: $post,
|
||
install: (app) => {
|
||
app.config.globalProperties['$get'] = $get;
|
||
app.config.globalProperties['$post'] = $post;
|
||
app.config.globalProperties['$axios'] = axios;
|
||
}
|
||
} |