首页 >web前端 >js教程 >如何解决 XMLHttpRequest 文件上传中的'多部分边界”错误?

如何解决 XMLHttpRequest 文件上传中的'多部分边界”错误?

Barbara Streisand
Barbara Streisand原创
2024-10-18 16:38:291050浏览

How to Resolve the

XMLHttpRequest 文件上传故障排除

使用 XMLHttpRequest 上传文件有时会遇到错误,尤其是在处理多部分数据时。下面详细分析了涉及“多部分边界”错误的常见问题。

提供的代码尝试使用 XMLHttpRequest 上传文件,但失败并出现以下错误:

The request was rejected because no multipart boundary was found.

文件附件不正确

初始代码包括行 xhr.file = file;。但是,这不是将文件附加到 XMLHttpRequest 的标准方法。文件对象应包装在 FormData 对象内。

表单数据使用

要解决此问题,请替换 xhr.send(file);使用以下代码:

var formData = new FormData();
formData.append("thefile", file);
xhr.send(formData);

Multipart/Form-Data 标头

确保之前将 Content-Type 标头设置为“multipart/form-data”发送请求:

xhr.setRequestHeader("Content-Type", "multipart/form-data");

附加说明

  • FormData 对象创建一个 multipart/form-data 请求对象,可以在服务器上使用解析PHP 的 $_FILES['thefile'].
  • 有关 XMLHttpRequest 文件上传的更多信息,请参阅 Mozilla Hack 演示和 MDC 文档。

按照以下步骤操作并更正代码错误,就可以使用XMLHttpRequest成功上传文件了。

以上是如何解决 XMLHttpRequest 文件上传中的'多部分边界”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn