小程序环境中处理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对象的环境中,这是一种可行的解决方案。

相关推荐
@大迁世界3 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
tongluowan0073 小时前
一个请求在Spring MVC 中是怎么流转的
java·spring·mvc
千叶风行3 小时前
Text-to-SQL 技术设计与注意事项
前端·人工智能·后端
夜郎king3 小时前
Spring AI 对接大模型开发易错点总结与实战解决办法
java·人工智能·spring
软件开发技术深度爱好者3 小时前
HTML5+JavaScript读取DOCX 文档完整内容
前端·html5
oradh4 小时前
Oracle数据库中的Java概述
java·数据库·oracle·sql基础·oracle数据库java概述
幽络源小助理4 小时前
苹果CMS V10 MXPro V4.5模版下载, 自适应视频主题源码, 幽络源源码
前端·开源·源码·php源码
组合缺一4 小时前
Java AI 框架三国杀:Solon AI vs Spring AI vs LangChain4j 深度对比
java·人工智能·spring·ai·langchain·llm·solon
c++之路4 小时前
适配器模式(Adapter Pattern)
java·算法·适配器模式
kyriewen4 小时前
坏了,黑客学会用AI写外挂了
前端·程序员·ai编程