|
@@ -1,9 +1,9 @@
|
|
|
-import { Code } from '@/enum/app'
|
|
|
-import axios, { AxiosInstance, AxiosRequestConfig } from 'axios'
|
|
|
-import { env, getAuthToken, removeAuthToken } from '@/support/helper'
|
|
|
-import Message from '@/support/message'
|
|
|
-import router from '@/router'
|
|
|
-import ResponseData from '@/types/responseData'
|
|
|
+import { Code } from '@/enum/app';
|
|
|
+import axios, { AxiosInstance, AxiosRequestConfig } from 'axios';
|
|
|
+import { env, getAuthToken, removeAuthToken } from '@/support/helper';
|
|
|
+import Message from '@/support/message';
|
|
|
+import router from '@/router';
|
|
|
+import ResponseData from '@/types/responseData';
|
|
|
|
|
|
/**
|
|
|
* http util
|
|
@@ -13,40 +13,40 @@ class Http {
|
|
|
* axios config
|
|
|
* @protected
|
|
|
*/
|
|
|
- protected config: AxiosRequestConfig = {}
|
|
|
+ protected config: AxiosRequestConfig = {};
|
|
|
|
|
|
/**
|
|
|
* base url
|
|
|
* @protected
|
|
|
*/
|
|
|
- protected baseURL: string = ''
|
|
|
+ protected baseURL: string = '';
|
|
|
|
|
|
/**
|
|
|
* http request timeout
|
|
|
*
|
|
|
* @protected
|
|
|
*/
|
|
|
- protected timeout: number = 0
|
|
|
+ protected timeout: number = 0;
|
|
|
|
|
|
/**
|
|
|
* http request headers
|
|
|
*
|
|
|
* @protected
|
|
|
*/
|
|
|
- protected headers: { [k: string]: string } = {}
|
|
|
+ protected headers: { [k: string]: string } = {};
|
|
|
|
|
|
/**
|
|
|
* axios instance
|
|
|
*
|
|
|
* @protected
|
|
|
*/
|
|
|
- protected request: AxiosInstance
|
|
|
+ protected request: AxiosInstance;
|
|
|
|
|
|
/**
|
|
|
* instance
|
|
|
*/
|
|
|
constructor() {
|
|
|
- this.request = axios.create(this.getConfig())
|
|
|
+ this.request = axios.create(this.getConfig());
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -57,8 +57,8 @@ class Http {
|
|
|
*/
|
|
|
public get(path: string, params: object = {}) {
|
|
|
return this.request.get(this.baseURL + path, {
|
|
|
- params,
|
|
|
- })
|
|
|
+ params
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -68,7 +68,7 @@ class Http {
|
|
|
* @param data
|
|
|
*/
|
|
|
public post(path: string, data: object = {}) {
|
|
|
- return this.request.post(this.baseURL + path, data)
|
|
|
+ return this.request.post(this.baseURL + path, data);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -78,7 +78,7 @@ class Http {
|
|
|
* @param data
|
|
|
*/
|
|
|
public put(path: string, data: object = {}) {
|
|
|
- return this.request.put(this.baseURL + path, data)
|
|
|
+ return this.request.put(this.baseURL + path, data);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -87,7 +87,7 @@ class Http {
|
|
|
* @param path
|
|
|
*/
|
|
|
public delete(path: string) {
|
|
|
- return this.request.delete(this.baseURL + path)
|
|
|
+ return this.request.delete(this.baseURL + path);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -97,9 +97,9 @@ class Http {
|
|
|
* @returns
|
|
|
*/
|
|
|
public setTimeout(timeout: number): Http {
|
|
|
- this.timeout = timeout
|
|
|
+ this.timeout = timeout;
|
|
|
|
|
|
- return this
|
|
|
+ return this;
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -109,9 +109,9 @@ class Http {
|
|
|
* @returns
|
|
|
*/
|
|
|
public setBaseUrl(url: string): Http {
|
|
|
- this.baseURL = url
|
|
|
+ this.baseURL = url;
|
|
|
|
|
|
- return this
|
|
|
+ return this;
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -122,9 +122,9 @@ class Http {
|
|
|
* @returns
|
|
|
*/
|
|
|
public setHeader(key: string, value: string): Http {
|
|
|
- this.headers.key = value
|
|
|
+ this.headers.key = value;
|
|
|
|
|
|
- return this
|
|
|
+ return this;
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -134,18 +134,18 @@ class Http {
|
|
|
*/
|
|
|
protected getConfig(): AxiosRequestConfig {
|
|
|
// set base url
|
|
|
- this.config.baseURL = this.baseURL ? this.baseURL : env('VITE_BASE_URL')
|
|
|
+ this.config.baseURL = this.baseURL ? this.baseURL : env('VITE_BASE_URL');
|
|
|
|
|
|
// set timeout
|
|
|
- this.config.timeout = this.timeout ? this.timeout : 60000
|
|
|
+ this.config.timeout = this.timeout ? this.timeout : 60000;
|
|
|
|
|
|
// set ajax request
|
|
|
- this.headers['X-Requested-With'] = 'XMLHttpRequest'
|
|
|
+ this.headers['X-Requested-With'] = 'XMLHttpRequest';
|
|
|
// set dashboard request
|
|
|
- this.headers['Request-from'] = 'Dashboard'
|
|
|
- this.config.headers = this.headers
|
|
|
+ this.headers['Request-from'] = 'Dashboard';
|
|
|
+ this.config.headers = this.headers;
|
|
|
|
|
|
- return this.config
|
|
|
+ return this.config;
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -153,18 +153,20 @@ class Http {
|
|
|
*
|
|
|
*/
|
|
|
public interceptorsOfRequest(): void {
|
|
|
- this.request.interceptors.request.use(function (config: AxiosRequestConfig) {
|
|
|
- const token = getAuthToken()
|
|
|
+ this.request.interceptors.request.use(function (
|
|
|
+ config: AxiosRequestConfig
|
|
|
+ ) {
|
|
|
+ const token = getAuthToken();
|
|
|
if (token) {
|
|
|
if (!config.headers) {
|
|
|
- config.headers = {}
|
|
|
+ config.headers = {};
|
|
|
}
|
|
|
|
|
|
- config.headers.authorization = 'Bearer ' + token
|
|
|
+ config.headers.authorization = 'Bearer ' + token;
|
|
|
}
|
|
|
|
|
|
- return config
|
|
|
- })
|
|
|
+ return config;
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -174,42 +176,49 @@ class Http {
|
|
|
public interceptorsOfResponse(): void {
|
|
|
this.request.interceptors.response.use(
|
|
|
response => {
|
|
|
- const r: ResponseData = response.data
|
|
|
- const code = r.code
|
|
|
- const message = r.message
|
|
|
+ const r: ResponseData = response.data;
|
|
|
+ const code = r.code;
|
|
|
+ const message = r.message;
|
|
|
if (code === 1e4) {
|
|
|
- return r
|
|
|
+ return r;
|
|
|
}
|
|
|
|
|
|
if (code === 10004) {
|
|
|
- Message.error(message || 'Error')
|
|
|
+ Message.error(message || 'Error');
|
|
|
} else if (code === Code.LOST_LOGIN || code === Code.LOGIN_EXPIRED) {
|
|
|
// to re-login
|
|
|
Message.confirm(message + ',需要重新登陆', function () {
|
|
|
- removeAuthToken()
|
|
|
- router.push('/login')
|
|
|
- })
|
|
|
- } else if (code === Code.LOGIN_BLACKLIST || code === Code.USER_FORBIDDEN) {
|
|
|
- Message.error(message || 'Error')
|
|
|
- removeAuthToken()
|
|
|
+ removeAuthToken();
|
|
|
+ router.push('/login');
|
|
|
+ });
|
|
|
+ } else if (
|
|
|
+ code === Code.LOGIN_BLACKLIST ||
|
|
|
+ code === Code.USER_FORBIDDEN
|
|
|
+ ) {
|
|
|
+ Message.error(message || 'Error');
|
|
|
+ removeAuthToken();
|
|
|
// to login page
|
|
|
- router.push('/login')
|
|
|
+ router.push('/login');
|
|
|
+ } else if (code === -2333) {//对视频上传错误特殊处理的状态码
|
|
|
+ ElMessageBox.alert(
|
|
|
+ `上传失败,《${message}》文件名已存在,请修改后重新上传`
|
|
|
+ );
|
|
|
} else {
|
|
|
- Message.error(message || 'Error')
|
|
|
+ Message.error(message || 'Error');
|
|
|
}
|
|
|
|
|
|
- return Promise.reject(new Error(message || 'Error'))
|
|
|
+ return Promise.reject(new Error(message || 'Error'));
|
|
|
},
|
|
|
error => {
|
|
|
- Message.error(error.message)
|
|
|
- return Promise.reject(error)
|
|
|
- },
|
|
|
- )
|
|
|
+ Message.error(error.message);
|
|
|
+ return Promise.reject(error);
|
|
|
+ }
|
|
|
+ );
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-const http = new Http()
|
|
|
-http.interceptorsOfRequest()
|
|
|
+const http = new Http();
|
|
|
+http.interceptorsOfRequest();
|
|
|
|
|
|
-http.interceptorsOfResponse()
|
|
|
-export default http
|
|
|
+http.interceptorsOfResponse();
|
|
|
+export default http;
|