【问题标题】:Ajax request with formdata returns error 'request entity too large'带有 formdata 的 Ajax 请求返回错误“请求实体太大”
【发布时间】:2018-10-26 15:57:47
【问题描述】:

我正在尝试使用 FormData 发送带有文件的表单,在现代桌面浏览器中它工作正常,但在手机中我的代码返回错误“请求实体太大”。 我已经在 iphone 5s (iOS 11) Safari 和 android Firefox 上进行了测试。

有代码:

window.xhrJson = function (url, method, data, customParams) {
    return xhr(url, method, 'JSON', data, customParams);
};
window.xhr = function (url, method, dataType, data, customParams) {
    var params = {
        url: url,
        headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') },
        method: method,
        dataType: dataType
    };
    if (typeof data !== 'undefined') {
        params.data = data;
    }
    if (typeof customParams !== 'undefined') {
        params = mergeOptions(params, customParams);
    }
    return $.ajax(params);
};
window.mergeOptions = function(obj1,obj2){
    var obj3 = {};
    for (var attrname in obj1) { obj3[attrname] = obj1[attrname]; }
    for (var attrname in obj2) { obj3[attrname] = obj2[attrname]; }
    return obj3;
};

// Main function to upload form with files
window.upload = function ($form, url) {
    var xhr = xhrJson(url, 'POST', new FormData($form[0]), {
        contentType: false,
        processData: false
    });
    xhr.fail(function (data, status, err) {
        alert(err);
    }).done(function (data) {

    });
    return xhr;
};

【问题讨论】:

  • 与你的服务器设置有关,与Ajax无关。您发送的文件大小大于服务器允许的大小。
  • 我已经更改了服务器上所有可能的设置。正如我在桌面上所说,它工作正常,我发送了 70Mb 大小的图像。

标签: javascript ajax html file-upload


【解决方案1】:

好的,我发现了问题。我的手机使用了未正确配置的本地代理服务器。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-11-23
    • 2019-03-17
    • 1970-01-01
    • 2016-08-05
    • 2016-02-10
    • 2016-02-01
    • 2018-12-14
    • 1970-01-01
    相关资源
    最近更新 更多