axios

该博客主要介绍了如何使用axios库设置请求和响应拦截器,用于处理请求前的token添加以及响应后的不同状态码错误提示。当遇到特定错误时,如401未登录、403权限不足等,会显示相应错误信息并执行相应操作,如跳转至登录页面。
摘要由CSDN通过智能技术生成
import axios from 'axios'
import {Message} from 'element-ui';
import router from '../router';

//请求拦截器
axios.interceptors.request.use(config=>{
	//如果存在token,请求携带这个token
	if (window.sessionStorage.getItem('tokenStr')){
		config.headers['Authorization'] = window.sessionStorage.getItem('tokenStr')
	}
	return config;
},error => {
	console.log(error);
})



//响应拦截器
axios.interceptors.response.use( success => {
	//业务逻辑错误
	if(success.status&& success.status==200){
		if(success.data.code==500||success.data.code==401||success.data.code==403){
			Message.error({message:success.data.message});
			return;
		}
		if(success.data.message){
			Message.success({message:success.data.message});
		}
	}
	return success.data;
}, error => {
	if (error.response.code == 504 || error.response.code == 404) {
		Message.error({message:'服务器无反应'});
	}else if(error.response.code==403){
		Message.error({message:'权限不足,请联系管理员!'})
	}else if(error.response.code == 401){
		Message.error({message:'未登录,请登录!'});
		router.replace('/')
	}else {
		if (error.response.data.message) {
			Message.error({message:error.response.data.message})
		}else {
			Message.error({ message:'未知错误'})
		}
	}
	return;
});

//设置前置路径
let base = '';
//传送json格式的post请求
export const postRequest = (url,params) =>{
	return axios({
		method: 'post',
		url: '${base}${url}',
		data: params
	})
}

//传送json格式的put请求
export const putRequest = (url,params) =>{
	return axios({
		method: 'put',
		url: '${base}${url}',
		data: params
	})
}

//传送json格式的get请求
export const getRequest = (url,params) =>{
	return axios({
		method: 'get',
		url: '${base}${url}',
		data: params
	})
}

//传送json格式的delete请求
export const deleteRequest = (url,params) =>{
	return axios({
		method: 'delete',
		url: '${base}${url}',
		data: params
	})
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值