Vue数据请求拦截

在src文件夹下创建utils文件夹

在这里插入图片描述

同时在文件夹下创建request.js和auth.js文件


	request.js为请求拦截、请求数据封装主入口
	auth.js为设置token和删除token及判断用户是否登录封装主入口 
	

auth.js (封装token)


		export function isLogin() {
		  if (localStorage.getItem('token')) {
		    return true;
		  } else {
		    return false;
		  }
		}
		export function getToken() {
		  return localStorage.getItem('token');
		}
		export function setToken(token) {
		  localStorage.setItem('token', token);
		}
		
		export function removeToken() {
		  localStorage.removeItem('token');
		}


下载axios(命令: npm install axios --save-dev)、同时引入axios、getToken


		import axios from 'axios';
		import { getToken } from './auth';

创建实例:传两个参数(timeout(超时时间)、baseUrl(服务器路径))

		const instance = axios.create({
		  	timeout: 5000,
		  	baseURL: 'https://xxxxxxxxx/xxxx/',
		});
		
请求拦截

		// 请求拦截
		instance.interceptors.request.use(
		  function(config) {
		    // eslint-disable-next-line prettier/prettier
		    config.headers.authorization = 'Bearer ' + getToken();
		    return config;
		  },
		  function(error) {
		    // Do something with request error
		    return Promise.reject(error);
		  }
		);
		
		instance.interceptors.response.use(
		  response => {
		    return response;
		  },
		  error => {
		    if (error.response.status == 401) {
		      window.location.href = '/#/login';
		    }
		    if (error.response.status == 404) {
		      window.location.href = '/404.html';
		    }
		    return Promise.reject(error.response.data);
		  }
		);

请求封装

		/**
		 * 获取数据 get请求
		 * @param {*} url
		 * @param {*} config
		 */
		export const get = (url, config) => instance.get(url, config);
		
		/**
		 * post请求
		 * @param {*} url
		 * @param {*} data
		 * @param {*} config
		 */
		export const post = (url, data) => instance.post(url, data);
		/**
		 * put
		 * @param {*} url
		 * @param {*} data
		 * @param {*} config
		 */
		export const put = (url, data, config) => instance.put(url, data, config);
		
		/**
		 * delete
		 * @param {*} url
		 * @param {*} config
		 */
		export const remove = (url, config) => instance.delete(url, config);

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值