android - 仅在 Android 上使用 FormData 网络错误获取 React Native(带 expo)

标签 android react-native fetch expo form-data

当我尝试使用 fetch 和 FormData 在 POST 中使用 React native (expo SDK 37) 进行 fetch API 调用时,在 IOS 上一切正常,但它使Android 上的网络错误:[TypeError: Network request failed]。如果我使用 axios 而不是 fetch,我会遇到同样的错误(网络错误)。

如果我用空的 {} 替换 formData,它就可以工作。 我已经检查了模拟器和物理设备(具有各种 Android 版本),并且我尝试使用标题但没有结果。我的 API 有一个有效的让我们加密证书

let url = 'https://my-prod-server/webservice';

let formData = new FormData();
formData.append('test1','test1');
formData.append('test2','test2');

let request = await fetch(url, {
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'multipart/form-data',
  },
  method: 'POST',
  body: formData,
})
.then(response => response.json())
.catch(error => console.log('API ERROR: ', error));

return request;

最佳答案

我在 expo SDK 38 上尝试使用 fetch 和 FormData 发布图像时遇到了同样的问题。请求在 iPhone 上成功,而在 Android 上失败并显示 [TypeError: Network request failed]。经过进一步调查,我发现我的请求根本没有到达服务器,问题似乎出在仅使用 FormData 上。使用 FormData 的请求可能超时/被拒绝并导致错误。当我遇到一篇提到 XMLHttpRequest 的帖子时,我浪费了很多时间来寻找答案并尝试实现建议的解决方案,但没有任何帮助。在这种特殊情况下,我最终使用了 XMLHttpRequest 而不是 fetch,它在 Android 设备和 iPhone 上与 FormData 一起工作就像一个魅力。

声明一个函数如下,并将<和>之间的值替换为合适的值

function sendXmlHttpRequest(data) {
  const xhr = new XMLHttpRequest();

  return new Promise((resolve, reject) => {
    xhr.onreadystatechange = e => {
      if (xhr.readyState !== 4) {
        return;
      }

      if (xhr.status === 200) {
        resolve(JSON.parse(xhr.responseText));
      } else {
        reject("Request Failed");
      }
    };
    xhr.open("POST", <apiEndpoint>);
    xhr.setRequestHeader(<headerName>, <value>);
    xhr.send(data);
  });
}

现在在您的代码中的某处,创建一个新的 FormData 对象并附加任何相关字段/信息,然后最后调用将处理请求的 sendXmlHttpRequest 函数。

const photoData = new FormData();
photoData.append("photo", {
  uri: <uri of the photo>,
  name: filename,
  type: "image/jpeg"
});

const response = await sendXmlHttpRequest(photoData);

关于android - 仅在 Android 上使用 FormData 网络错误获取 React Native(带 expo),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60987459/

相关文章:

android - 设置 ShareActionProvider 的颜色

java - libgdx - Android 问题 - "Unfortunately [app name] has stopped"

java - 在应用程序中更新,而不是从市场更新

android - getView 方法返回错误位置

PHP - MySQL "next"- "previous"链接与订购

javascript - 无法在 React Native Paper 中更改卡片标题文本的颜色

react-native - Realm : delete specific object

javascript - React-native- 如果数组为空,则有条件地禁用 TouchableHighlight

javascript - 未捕获的类型错误: data.reduce不是一个函数

javascript - 错误 : Request failed with status code 403 - Problem with Axios, 可能用于获取交换