【问题标题】:Image upload to Imgur API via JS Fetch API is canceled by browser浏览器取消通过 JS Fetch API 上传到 Imgur API 的图像
【发布时间】:2023-03-04 14:02:01
【问题描述】:

我写了a small application on Codepen 以使用 Javascript 的 Fetch API 上传到特定的 Imgur 相册。该应用程序无法上传,我不确定为什么,因为我实际上没有从服务器获得响应。浏览器似乎正在取消请求而不是发送它。

这是我的代码:

const form = document.querySelector('form');
form.addEventListener('submit', event => {
  const fileInput = event.target.querySelector('input');
  const imageFile = fileInput.files[0];

  const formData = new FormData();
  formData.append('image', imageFile);
  formData.append('album', 'EVGILvAjGfArJFI');

  fetch('https://api.imgur.com/3/image', {
    method: 'POST',
    headers: new Headers({
      'Content-Type': 'multipart/form-data',
      Authorization: 'Client-ID 90ef1830bd083ba',
    }),
    body: formData
  }).then(response => {
    if (response.ok) {
      alert('Image uploaded to album');       
    }
  }).catch(error => {
    console.error(JSON.stringify(error));
    alert('Upload failed: ' + error);
  });
});

我不确定是否需要读取文件,或者是否可以将文件对象直接传递到表单数据中。我在网上看到了这两种方法的例子,我都试过了,结果都是一样的。我注意到开发工具似乎没有在请求正文中显示图像数据。不确定这是否意味着它没有被发送,或者 Chrome 是否只是没有显示它,因为它无论如何都不是人类可读的。我已经尝试过开启和关闭 CORS 模式的请求。

关于我在这里做错了什么的任何指导?

【问题讨论】:

  • 您还需要将init:{credentials: "include"} 选项附加到您的fetch 吗?否则它不会发送 cookie。
  • @zero298 它似乎不需要 cookie。请求所需的唯一身份验证是 Authorization 标头。

标签: javascript fetch imgur


【解决方案1】:

对于 FormData,您实际上并不需要 Content-Type 标头。当正文中有 FormData 类型时,浏览器会自动为您添加。我认为这是因为该标头需要一些额外的信息(当浏览器自动处理它时,它在我的机器上看起来像 multipart/form-data; boundary=----WebKitFormBoundaryvAmR7mCXOyHiPIH5)。

这是看起来可以正常工作的更新笔: https://codepen.io/ccnokes/pen/wyBYOd

此外,由于您是通过 <form> 提交该数据,但通过 fetch 处理请求,您需要告诉 <form> 不要进行整页导航更改以发布表单(这会取消拿来)。所以我在该表单的submit 处理程序中添加了event.preventDefault()

【讨论】:

  • 这确实有效。看起来请求仍然抛出,但请求确实到达了 Imgur,并且图像最终出现在相册中。感谢您的帮助!
  • 刚刚再次测试它并没有为我抛出。诡异的。嗯,很高兴它有帮助!
  • 刚刚注意到您所做的另一项至关重要的更改:event.preventDefault()。我认为事件传播导致我的获取请求被表单提交取消。可能也想将其添加到您的答案中。
  • @raddevon 哦,是的,忘记了。更新了。
猜你喜欢
  • 2015-02-22
  • 1970-01-01
  • 2015-03-12
  • 2017-10-21
  • 1970-01-01
  • 2013-06-25
  • 2019-07-05
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多