一步步创建一个vue项目(六)封装axios
安装axios
npm install axios -S
在utils文件下创建http.js文件,里面写:
import axios from 'axios';
// import { Toast } from 'vant';
import {
Message,
MessageBox
} from 'element-ui';
import store from '../store'; //这里是为了调用store的FedLogOut方法,可以不使用
import {
getToken
} from 'utils/auth'; //这里是为了获取token
// 创建axios实例
const service = axios.create({
baseURL: process.env.BASE_API, // api的base_url
timeout: 50000 // 请求超时时间
});
// request拦截器
service.interceptors.request.use(config => {
// Do something before request is sent
if (getToken()) {
config.headers.Authorization = getToken();
// 让每个请求携带token--['Authorization']为自定义key 请根据实际情况自行修改
}
return config;
}, error => {
// Do something with request error
console.log(error); // for debug
Promise.reject(error);
})
// respone拦截器
service.interceptors.response.use(
response => {
/**
* 下面的注释为通过response自定义code来标示请求状态,当code返回如下情况为权限有问题,登出并返回到登录页
* 如通过xmlhttprequest 状态码标识 逻辑可写在下面error中
*/
const res = response.data;
if (res.code === 401 || res.code === 40101) {
MessageBox.confirm('你已被登出,可以取消继续留在该页面,或者重新登录', '确定登出', {
confirmButtonText: '重新登录',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
store.dispatch('FedLogOut').then(() => {
location.reload(); // 为了重新实例化vue-router对象 避免bug
});
})
return Promise.reject('error');
}
if (res.status === 40301) {
Message({
message: '当前用户无相关操作权限!',
type: 'error',
duration: 5 * 1000
});
return Promise.reject('error');
}
if (res.code === 40001) {
Message({
message: '账户或密码错误!',
type: 'warning'
});
return Promise.reject(res);
}
if (res.success === undefined || res.success) {
return response.data;
} else {
Message({
message: res.msg,
type: 'error'
});
return Promise.reject(res);
}
},
error => {
// console.log(error); // for debug
Message({
message: error.message,
type: 'error',
duration: 5 * 1000
});
return Promise.reject(error);
}
);
export default service;
在接口文件中:
比如创建一个接口文件
import https from '../utils/http'
export function login (params) {
return https({
url: '/api/auth/jwt/token',
method: 'post',
data: params
})
}
export function logout (token) {
return https({
url: '/api/auth/jwt/invalid',
method: 'get',
params: { token }
});
}
在代码中引用:
import { login, logout} from 'api的路径'
方法名 () {
login().then(res => {
xxxx
})
}