javascript - 浏览器取消了通过 JS Fetch API 将图像上传到 Imgur API

标签 javascript fetch imgur

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

Chrome dev tools network tab request canceled

Chrome dev tools request details

这是我的代码:

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 模式的请求。

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

最佳答案

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

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

此外,因为您要通过 <form> 提交该数据但通过 fetch 处理请求, 你需要告诉 <form>不要做一个完整的页面导航更改来发布表单(这会取消获取)。所以我添加了 event.preventDefault()submit该表格上的处理程序。

关于javascript - 浏览器取消了通过 JS Fetch API 将图像上传到 Imgur API,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48513163/

相关文章:

javascript - 奥里利亚导航管道

javascript - Vue 自定义指令

javascript - 处理Promise中的错误

reactjs - React-fetch 和 Whatwg-fetch 有什么区别

java - 将 Retrofit 与 Imgur 的 API 结合使用

javascript - 如何将 char 添加到 javascript 对象键和值?

javascript - 如何在 AngularJs 中按日期范围搜索

javascript - svelte 组件不会访问 .env

image - 谷歌浏览器重新托管图片扩展

angular - Imgur 嵌入在 Angular Web 应用程序中不显示图像