简单封装axios

目录

一、代码解读

import axios from 'axios';

创建一个名为 instance 的 Axios 实例,配置默认的请求地址和超时时间

javascript 复制代码
const instance = axios.create({
    baseURL: 'http://localhost:8085',
    timeout: 5000,
});

请求拦截器,用于在请求发送前进行处理,比如在请求头中添加 token ,在请求发送之前,如果有需要,可以在请求头中加入认证信息

javascript 复制代码
instance.interceptors.request.use(
    (config) => {
        // config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`;
        return config;
    },
    (error) => {
        return Promise.reject(error);
    }
);

响应拦截器,用于统一处理后端返回的错误信息

javascript 复制代码
instance.interceptors.response.use(
    (response) => {
        // 对后端返回的数据进行统一处理
        const data = response.data;
        // 如果返回的状态码不是 200,则输出错误信息到控制台
        if (data.code !== 200) {
            console.error(`Error: ${data.message}`);
        }
        return data;
    },
    (error) => {
        // 处理响应错误,输出错误信息到控制台
        console.error('Response Error:', error);
        return Promise.reject(error);
    }
);

封装 GET 请求方法,支持传入请求地址和参数

javascript 复制代码
function get(url, params = {}) {
    return instance.get(url, { params });
}

封装 POST 请求方法,支持传入请求地址和数据

javascript 复制代码
function post(url, data = {}) {
    return instance.post(url, data);
}

封装上传文件的方法,支持传入请求地址和文件

javascript 复制代码
function uploadFile(url, file) {
    // 创建一个 FormData 对象,用于上传文件
    const formData = new FormData();
    formData.append('file', file);
    // 使用 POST 方法上传文件,并设置请求头的 Content-Type 为 multipart/form-data
    return instance.post(url, formData, {
        headers: {
            'Content-Type': 'multipart/form-data',
        },
    });
}

导出封装好的 GET、POST 和上传文件的方法

javascript 复制代码
export { get, post, uploadFile };

二、整体代码

javascript 复制代码
import axios from 'axios';

const instance = axios.create({
    baseURL: 'http://localhost:8085',
    timeout: 5000,
});

instance.interceptors.request.use(
    (config) => {
        // config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`;
        return config;
    },
    (error) => {
        return Promise.reject(error);
    }
);

instance.interceptors.response.use(
    (response) => {
        const data = response.data;
        if (data.code !== 200) {
            console.error(`Error: ${data.message}`);
        }
        return data;
    },
    (error) => {
        console.error('Response Error:', error);
        return Promise.reject(error);
    }
);

function get(url, params = {}) {
    return instance.get(url, { params });
}

function post(url, data = {}) {
    return instance.post(url, data);
}

function uploadFile(url, file) {
    const formData = new FormData();
    formData.append('file', file);
    return instance.post(url, formData, {
        headers: {
            'Content-Type': 'multipart/form-data',
        },
    });
}

export { get, post, uploadFile };
相关推荐
寻星探路17 分钟前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
崔庆才丨静觅2 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
曹牧3 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
passerby60613 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了3 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅3 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅3 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
爬山算法3 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7254 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎4 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven