2022-10-08 11:35:16 +08:00
|
|
|
import axios, {
|
|
|
|
AxiosInstance,
|
|
|
|
AxiosRequestConfig,
|
|
|
|
AxiosRequestHeaders,
|
|
|
|
AxiosResponse,
|
|
|
|
AxiosError
|
|
|
|
} from 'axios'
|
2022-08-13 09:32:13 +08:00
|
|
|
|
|
|
|
import qs from 'qs'
|
|
|
|
|
|
|
|
import { config } from './config'
|
|
|
|
|
|
|
|
import { ElMessage } from 'element-plus'
|
|
|
|
|
|
|
|
const { result_code, base_url } = config
|
|
|
|
|
|
|
|
export const PATH_URL = base_url[import.meta.env.VITE_API_BASEPATH]
|
|
|
|
|
|
|
|
// 创建axios实例
|
|
|
|
const service: AxiosInstance = axios.create({
|
|
|
|
baseURL: PATH_URL, // api 的 base_url
|
|
|
|
timeout: config.request_timeout // 请求超时时间
|
|
|
|
})
|
|
|
|
|
|
|
|
// request拦截器
|
|
|
|
service.interceptors.request.use(
|
|
|
|
(config: AxiosRequestConfig) => {
|
|
|
|
if (
|
|
|
|
config.method === 'post' &&
|
2022-10-08 11:35:16 +08:00
|
|
|
(config.headers as AxiosRequestHeaders)['Content-Type'] ===
|
|
|
|
'application/x-www-form-urlencoded'
|
2022-08-13 09:32:13 +08:00
|
|
|
) {
|
|
|
|
config.data = qs.stringify(config.data)
|
|
|
|
}
|
2022-10-08 11:35:16 +08:00
|
|
|
// ;(config.headers as AxiosRequestHeaders)['Token'] = 'test test'
|
2022-08-13 09:32:13 +08:00
|
|
|
// get参数编码
|
|
|
|
if (config.method === 'get' && config.params) {
|
|
|
|
let url = config.url as string
|
|
|
|
url += '?'
|
|
|
|
const keys = Object.keys(config.params)
|
|
|
|
for (const key of keys) {
|
|
|
|
if (config.params[key] !== void 0 && config.params[key] !== null) {
|
|
|
|
url += `${key}=${encodeURIComponent(config.params[key])}&`
|
|
|
|
}
|
|
|
|
}
|
|
|
|
url = url.substring(0, url.length - 1)
|
|
|
|
config.params = {}
|
|
|
|
config.url = url
|
|
|
|
}
|
|
|
|
return config
|
|
|
|
},
|
|
|
|
(error: AxiosError) => {
|
|
|
|
// Do something with request error
|
|
|
|
console.log(error) // for debug
|
|
|
|
Promise.reject(error)
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
// response 拦截器
|
|
|
|
service.interceptors.response.use(
|
|
|
|
(response: AxiosResponse<any>) => {
|
|
|
|
if (response.config.responseType === 'blob') {
|
|
|
|
// 如果是文件流,直接过
|
|
|
|
return response
|
|
|
|
} else if (response.data.code === result_code) {
|
|
|
|
return response.data
|
|
|
|
} else {
|
|
|
|
ElMessage.error(response.data.message)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
(error: AxiosError) => {
|
|
|
|
console.log('err' + error) // for debug
|
|
|
|
ElMessage.error(error.message)
|
|
|
|
return Promise.reject(error)
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
export { service }
|