You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

99 lines
3.3 KiB

6 years ago
import axios from 'axios'
5 years ago
import qs from 'qs'
6 years ago
import router from '@/router/index'
import store from '@/store/index'
5 years ago
import signMd5Utils from '@/util/sign'
6 years ago
const toLogin = () => {
router.push({
path: '/login',
query: {
redirect: router.currentRoute.fullPath
}
})
}
const api = axios.create({
5 years ago
baseURL: process.env.NODE_ENV !== 'development' && process.env.VUE_APP_API_ROOT,
timeout: 10000,
responseType: 'json',
6 years ago
withCredentials: false,
headers: {
'Content-Type': 'application/json; charset=utf-8'
}
})
api.interceptors.request.use(
request => {
5 years ago
/**
* 全局拦截请求发送前提交的参数
* 以下代码为示例在登录状态下分别对 post get 请求加上 token 参数
*/
6 years ago
if (request.method == 'post') {
if (request.data instanceof FormData) {
if (store.getters['token/isLogin']) {
// 如果是 FormData 类型(上传图片)
request.data.append('token', store.state.token.token)
}
} else {
// 带上 token
if (request.data == undefined) {
request.data = {}
}
if (store.getters['token/isLogin']) {
request.data.token = store.state.token.token
}
5 years ago
// 参数验签
6 years ago
let timestamp = new Date().getTime()
request.data.timestamp = '' + timestamp
let sign = signMd5Utils.getSign(request.url, request.data)
request.data.sign = sign
5 years ago
request.data = qs.stringify(request.data)
6 years ago
}
} else {
// 带上 token
if (request.params == undefined) {
request.params = {}
}
if (store.getters['token/isLogin']) {
request.params.token = store.state.token.token
}
let timestamp = new Date().getTime()
console.log(request.params)
request.params.timestamp = '' + timestamp
let sign = signMd5Utils.getSign(request.url, request.params)
request.params.sign = sign
}
return request
}
)
api.interceptors.response.use(
response => {
5 years ago
/**
* 全局拦截请求发送后返回的数据如果数据有报错则在这做全局的错误提示
* 假设返回数据格式为{ status: 1, error: '', data: '' }
* 规则是当 status 1 时表示请求成功 0 时表示接口需要登录或者登录状态失效需要重新登录
* 请求出错时 error 会返回错误信息
* 则代码如下
*/
if (response.data.status === 1) {
if (response.data.error === '') {
// 请求成功并且没有报错
return Promise.resolve(response.data)
} else {
// 这里做错误提示,如果使用了 element ui 则可以使用 Message 进行提示
// Message.error(options)
return Promise.reject(response.data)
6 years ago
}
5 years ago
} else {
toLogin()
6 years ago
}
},
error => {
return Promise.reject(error)
}
)
5 years ago
export default api