//进行axios二次封装:使用请求与响应拦截器 import axios from 'axios' import { ElMessage } from 'element-plus' // import useUserStore from '@/store/modules/user' //引入用户相关的仓库 // import useUserStore from '@/store/modules/user' //第一步:利用axios对象的create方法,去创建axios实例(其他的配置:基础路径、超时的时间) let request = axios.create({ //基础路径 baseURL: import.meta.env.VITE_API_BASE_URL, //基础路径上会携带/api timeout: 5000, //超时的时间的设置 withCredentials: true, // 异步请求携带cookie // headers: { // 设置后端需要的传参类型 // 'Content-Type': 'application/json', // 'token': x-auth-token',//一开始就要token // 'X-Requested-With': 'XMLHttpRequest', // }, }) //第二步:request实例添加请求与响应拦截器 request.interceptors.request.use((config) => { //获取用户相关的小仓库:获取仓库内部token,登录成功以后携带给服务器 // let userStore = useUserStore() // if (userStore.token) { // config.headers.token = userStore.token // } //config配置对象,headers属性请求头,经常给服务器端携带公共参数 //返回配置对象 return config }) //第三步:响应拦截器 request.interceptors.response.use( (response) => { //成功回调 //简化数据 return response.data }, (error) => { //失败回调:处理http网络错误的 //定义一个变量:存储网络错误信息 let message = '' //http状态码 let status = error.response.status switch (status) { case 401: message = 'TOKEN过期' break case 403: message = '无权访问' break case 404: message = '请求地址错误' break case 500: message = '服务器出现问题' break default: message = '网络出现问题' break } //提示错误信息 ElMessage({ type: 'error', message, }) return Promise.reject(error) }, ) //对外暴露 export default request