xinxin?

Vue:对axios进行简单的二次封装

主要做3点:

1、配置一个请求地址前缀

2、请求拦截(在请求发出去之前拦截),给所有的请求都带上 token

3、拦截响应,遇到 token 不合法则报错

// 对 axios 的二次封装
import axios from 'axios'
import router from '../router' // 引入路由对像,用于路由跳转

// 创建一个新的 axios 实例
axios.defaults.withCredentials = true //解决跨域后如何在请求里带上cookie的问题
var http = axios.create({
  baseURL: 'http://localhost:8080/',
  timeout: 8000, // 请求超时
})

// 请求拦截(在请求发出去之前拦截),给所有的请求都带上 token
http.interceptors.request.use(
  (config) => {
    const token = localStorage.getItem('token')
    if (token) {
      // 设置 token ,一般是在 headers 里加入 Authorization,并加上 Bearer 标注
      // 最好通过此种形式设置 request.headers['Authorization']
      config.headers['Authorization'] = token
    }
    return config
  },
  (error) => {
    console.log(error)
    return Promise.reject(error)
  }
)

// 拦截响应,遇到 token 不合法则报错
http.interceptors.response.use(
    response => {
        if (response.data.token) { // 将返回的最新的 token 保存
            localStorage.setItem('token', response.data.token);
        }
        return response;
    },
    error => {
        if (error.response.status === 401) {
            // 401 说明 token 验证失败
            // 可以直接跳转到登录页面,重新登录获取 token
            localStorage.removeItem('token');
            console.log(error.response.data.error.message);
            router.replace({
                path: '/login',
                query: {
                    redirect: router.currentRoute.fullPath
                }
            })
        } else if (error.response.status === 500) {
            // 服务器错误
            return Promise.reject('服务器出错:', error.response.data);
        }
        return Promise.reject(error.response.data); // 返回接口返回的错误信息
    });

export default http

 

posted on 2020-07-25 15:21  xinxin?  阅读(761)  评论(0编辑  收藏  举报

导航