Files
rustdesk-api-web/src/utils/request.js
T

81 lines
1.9 KiB
JavaScript
Raw Normal View History

2024-09-13 16:34:15 +08:00
import axios from 'axios'
import { ElMessage } from 'element-plus'
import { getToken, removeToken } from '@/utils/auth'
import { useUserStore } from '@/store/user'
import { pinia } from '@/store'
// create an axios instance
const service = axios.create({
baseURL: import.meta.env.VITE_SERVER_API,
withCredentials: true, // send cookies when cross-domain requests
timeout: 50000, // request timeout
})
// request interceptor
service.interceptors.request.use(
config => {
const userStore = useUserStore(pinia)
const token = userStore.token || getToken()
if (token) {
if (!config.headers) {
config.headers = {}
}
config.headers['api-token'] = token
}
return config
},
error => {
// do something with request error
return Promise.reject(error)
},
)
// response interceptor
service.interceptors.response.use(
/**
* If you want to get http information such as headers or status
* Please return response => response
*/
/**
* Determine the request status by custom code
* Here is just an example
* You can also judge the status by HTTP Status Code
*/
response => {
const res = response.data
// if the custom code is not 20000, it is judged as an error.
if (res.code !== 0) {
ElMessage({
message: res.message || 'error',
type: 'error',
duration: 5 * 1000,
})
if (res.code === 403) {
removeToken()
window.location.reload()
}
return Promise.reject(res.message || 'error')
} else {
return res
}
},
error => {
if (error.code === 'ECONNABORTED'
&& error.message.indexOf('timeout') > -1) {
error.message = '请求超时!'
}
ElMessage({
message: error.message,
type: 'error',
duration: 5 * 1000,
})
return Promise.reject(error)
},
)
export default service