javascript - 使用 formData 的 Ajax 文件上传在大文件上失败

标签 javascript jquery ajax upload form-data

我通过ajax发送一个包含上传文件的FormData对象,但是当我尝试上传大文件(> 5M)时,我收到空的$_POST和$_FILES变量。

读了很多关于这个问题的帖子,我几乎应用了所有内容,但没有奏效。

I've tried on php.ini:
- max_execution_time = 300
- max_input_time = 300
- post_max_size = 2048M (large but compulsory)
- upload_max_filesize = 2048M (large but compulsory)
- max_input_vars = 2000 (trying different values)

On HTTP/HTTPS directives (some have no sense but I was trying in a desperately way to see the behaviour):
- FcgidConnectTimeout 300
- FcgidIOTimeout 300
- FcgidIdleTimeout 300
- FcgidBusyTimeout 300
- IPCCommTimeout 9999
- FcgidMaxRequestLen 21474836480

我的代码如下所示:

var form = $('form[name="myform"]');
var formData = new FormData(form[0]);

/*
Also tried this:
   var file = $("form[name='myform'] input[name='filename']");
   formData.append("my_upload", (file[0]).files[0]);
*/

$.ajax({
   type: 'post',
   data: formData,
   dataType: 'json',
   async: true,
   url: '/mysite/controllers/Controller.php',
   processData: false,
   contentType: false,
   ...
});

因此,对于 < 5M 的文件,在我的本地服务器和生产服务器上一切都完美。对于> 5M 的文件仅适用于我的本地服务器,但不适用于生产服务器(我在其中收到空的 $_POST 和 $_FILES 变量)。尽管生产服务器位于 CloudFlare 上的 WAF 下,但它们通常具有一些变量配置。

最佳答案

我的设置也有同样的问题。我没有使用 jQuery,而是使用 vanilla js。

问题不是服务器!如果您查看浏览器的开发人员工具,您会发现 HTTP 请求没有表单数据。

小上传<6MB即可

Small Upload <6MB is fine

大上传 >=6MB 不会创建 FormData:

Big Upload >=6MB doesn't create FormData

我的代码是:

function uploadFile(file, filename, domDirectory, domTabelle, domSchluessel){
var fd = new FormData();
fd.append("filename", filename);
fd.append("name", filename);
fd.append("right_id", domDirectory);
fd.append("tabelle", domTabelle);
fd.append("schluessel", domSchluessel);
var xhr = new XMLHttpRequest();
var reader  = new FileReader();
reader.addEventListener("load", function () {
    fd.append("dataURI", reader.result);
    //console.log(reader.result);
    xhr.send(fd);
  }, false
);
reader.readAsDataURL(file);
xhr.open('POST', '../control/Upload.php', true);
}

关于javascript - 使用 formData 的 Ajax 文件上传在大文件上失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56343731/

相关文章:

javascript - 法语字符 html - javascript

jquery - 根据浏览器宽度显示图像

jquery - 元素相对于浏览器的 X 和 Y 位置(注 : Frames are involved)

javascript - 无法使用 XMLHttpRequest 执行 php 文件

c# - 是否可以根据IP地址强制登录?

javascript - Fancybox - 用于制作之前/之后的画廊

jquery - jqPlot荧光笔改变x值

javascript - AJAX 不返回 JSP 形式的值

javascript - 未捕获的类型错误 : Cannot read property 'responseText' of undefined

javascript - d3js 放大情节