Skip to content

Axios 笔记

request.js

/**
 * ajax模块是对axios的二次封装
 * @module ajax
 * */

import axios from 'axios'
import { ElMessageBox, ElMessage } from 'element-plus'
import { removeToken } from './auth'

const errorCode = {
	401: '认证失败,无法访问系统资源',
	403: '当前操作没有权限',
	404: '访问资源不存在',
	default: '系统未知错误,请反馈给管理员'
}

// 创建axios实例
const instance = axios.create({
	// 请求URL公共部分
	baseURL: import.meta.env.VITE_APP_BASE_API,
	// 设置网络请求超时时间
	timeout: 10000,
	// 跨域请求否要携带cookie
	withCredentials: true,
	// 请求头设置
	headers: {
		'Content-Type': 'application/json;charset=utf-8'
	}
})

// 请求拦截器
instance.interceptors.request.use(
	(config) => {
		return config
	},
	(error) => {
		console.error(error)
		Promise.reject(error)
	}
)

// 响应拦截器
instance.interceptors.response.use(
	(res) => {
		// 获取状态信息
		let code = res.data.code || 200
		// 获取错误信息
		const msg = errorCode[code] || res.data.msg || errorCode['default']
		if (code === 401) {
			ElMessageBox.alert('无效的会话,或者会话已过期,请重新登录。', '系统提示', {
				confirmButtonText: '确定',
				type: 'warning'
			}).then(() => {
				removeToken()
				location.href = '/index'
			})
			return Promise.reject('无效的会话,或者会话已过期,请重新登录。')
		} else if (code !== 200) {
			ElMessage({ message: msg, type: 'error' })
			return Promise.reject('error')
		} else {
			return Promise.resolve(res.data)
		}
	},
	(error) => {
		console.error('err' + error)
		let { message } = error
		if (message == 'Network Error') {
			message = '后端接口连接异常'
		} else if (message.includes('timeout')) {
			message = '系统接口请求超时'
		} else if (message.includes('Request failed with status code')) {
			message = '系统接口' + message.substr(message.length - 3) + '异常'
		}
		ElMessage({ message: message, type: 'error', duration: 5 * 1000 })
		return Promise.reject(error)
	}
)

function ajax(data) {
	let { method, url, params, headers = {} } = data

	let config = {
		url,
		method,
		headers: {
			...headers
		},
		params: method === 'get' ? params : null,
		data: method === 'post' || method === 'put' ? params : null
	}
	// console.log(config)

	return instance(config)
		.then(
			(value) => {
				let { data } = value
				let { code, message } = data
				if (code !== 20000) {
					console.error('response :', value, message)
				}
				return data
			},
			(reason) => {
				return Promise.reject(reason)
			}
		)
		.finally(() => {})
}

ajax.get = function (config) {
	return ajax({ method: 'get', ...config })
}

ajax.post = function (config) {
	return ajax({ method: 'post', ...config })
}

ajax.put = function (config) {
	return ajax({ method: 'put', ...config })
}

ajax.upload = function (config) {
	let { params } = config
	let formData = new FormData()
	for (let s in params) {
		formData.append(s, params[s])
	}

	return ajax({ method: 'post', ...config, params: formData })
}

export default ajax
/**
 * ajax模块是对axios的二次封装
 * @module ajax
 * */

import axios from 'axios'
import { ElMessageBox, ElMessage } from 'element-plus'
import { removeToken } from './auth'

const errorCode = {
	401: '认证失败,无法访问系统资源',
	403: '当前操作没有权限',
	404: '访问资源不存在',
	default: '系统未知错误,请反馈给管理员'
}

// 创建axios实例
const instance = axios.create({
	// 请求URL公共部分
	baseURL: import.meta.env.VITE_APP_BASE_API,
	// 设置网络请求超时时间
	timeout: 10000,
	// 跨域请求否要携带cookie
	withCredentials: true,
	// 请求头设置
	headers: {
		'Content-Type': 'application/json;charset=utf-8'
	}
})

// 请求拦截器
instance.interceptors.request.use(
	(config) => {
		return config
	},
	(error) => {
		console.error(error)
		Promise.reject(error)
	}
)

// 响应拦截器
instance.interceptors.response.use(
	(res) => {
		// 获取状态信息
		let code = res.data.code || 200
		// 获取错误信息
		const msg = errorCode[code] || res.data.msg || errorCode['default']
		if (code === 401) {
			ElMessageBox.alert('无效的会话,或者会话已过期,请重新登录。', '系统提示', {
				confirmButtonText: '确定',
				type: 'warning'
			}).then(() => {
				removeToken()
				location.href = '/index'
			})
			return Promise.reject('无效的会话,或者会话已过期,请重新登录。')
		} else if (code !== 200) {
			ElMessage({ message: msg, type: 'error' })
			return Promise.reject('error')
		} else {
			return Promise.resolve(res.data)
		}
	},
	(error) => {
		console.error('err' + error)
		let { message } = error
		if (message == 'Network Error') {
			message = '后端接口连接异常'
		} else if (message.includes('timeout')) {
			message = '系统接口请求超时'
		} else if (message.includes('Request failed with status code')) {
			message = '系统接口' + message.substr(message.length - 3) + '异常'
		}
		ElMessage({ message: message, type: 'error', duration: 5 * 1000 })
		return Promise.reject(error)
	}
)

function ajax(data) {
	let { method, url, params, headers = {} } = data

	let config = {
		url,
		method,
		headers: {
			...headers
		},
		params: method === 'get' ? params : null,
		data: method === 'post' || method === 'put' ? params : null
	}
	// console.log(config)

	return instance(config)
		.then(
			(value) => {
				let { data } = value
				let { code, message } = data
				if (code !== 20000) {
					console.error('response :', value, message)
				}
				return data
			},
			(reason) => {
				return Promise.reject(reason)
			}
		)
		.finally(() => {})
}

ajax.get = function (config) {
	return ajax({ method: 'get', ...config })
}

ajax.post = function (config) {
	return ajax({ method: 'post', ...config })
}

ajax.put = function (config) {
	return ajax({ method: 'put', ...config })
}

ajax.upload = function (config) {
	let { params } = config
	let formData = new FormData()
	for (let s in params) {
		formData.append(s, params[s])
	}

	return ajax({ method: 'post', ...config, params: formData })
}

export default ajax