小程序环境中处理multipart/form-data格式的请求

javascript 复制代码
const fetchExchangeRate = async () => {
    try {
      const boundary =
        "WebKitFormBoundary" + Math.random().toString(36).substring(2);
      const formData =
        `--${boundary}\r\n` +
        `Content-Disposition: form-data; name="path"\r\n\r\n` +
        `/api/exchange\r\n` +
        `--${boundary}\r\n` +
        `Content-Disposition: form-data; name="params"\r\n\r\n` +
        `${JSON.stringify({
          from: fromCurrency,
          to: toCurrency,
          money: parseFloat(amount) || 1,
        })}\r\n` +
        `--${boundary}--\r\n`;

      const response = await Taro.request({
        url: `https://xxx.com`,
        method: "POST",
        header: {
          "content-type": `multipart/form-data; boundary=${boundary}`,
        },
        data: formData,
      });

      // 处理响应...
      if (response.data.code === 200 && response.data.data) {
        const rate = response.data.data.exchange;
        setExchangeRate(rate);
        convertCurrency(amount, rate);
      } else {
        throw new Error("API 返回错误");
      }
    } catch (error) {
      console.error("获取汇率失败:", error);
      Taro.showToast({
        title: "获取汇率失败,请稍后再试",
        icon: "none",
      });
    }
  };

这个修改做了以下几点改变:

  • 我们手动创建了一个multipart/form-data格式的字符串。
  • 使用随机生成的boundary来分隔不同的表单字段。
  • 将content-type头部设置为multipart/form-data,并包含了boundary。
  • 直接发送构造好的formData字符串。

这种方法应该能够模拟您描述的请求格式。请注意,这种方法可能不够优雅,但在没有FormData对象的环境中,这是一种可行的解决方案。

相关推荐
我不只是切图仔11 分钟前
我只是想给网站加个注册验证码,咋就那么难!
前端·后端
野犬寒鸦14 分钟前
力扣hot100:相交链表与反转链表详细思路讲解(160,206)
java·数据结构·后端·算法·leetcode
JohnYan33 分钟前
工作笔记 - 微信消息发送和处理
javascript·后端·微信
该用户已不存在36 分钟前
macOS是开发的终极进化版吗?
前端·后端
小豆包api1 小时前
小豆包AI API × Nano Banana:3D手办 + AI视频生成,「动起来」的神级玩法!
前端·api
ytadpole1 小时前
揭秘设计模式:工厂模式的五级进化之路
java·设计模式
计算机毕业设计木哥1 小时前
计算机毕设选题:基于Python+Django的B站数据分析系统的设计与实现【源码+文档+调试】
java·开发语言·后端·python·spark·django·课程设计
失散131 小时前
分布式专题——1.2 Redis7核心数据结构
java·数据结构·redis·分布式·架构
陈陈爱java1 小时前
Spring八股文
开发语言·javascript·数据库
布列瑟农的星空1 小时前
大话设计模式——观察者模式和发布/订阅模式的区别
前端·后端·架构