我有一个用于 blueimp/jQuery 文件上传控件的自定义文件上传实现。它工作得很好,除非当我选择多个文件并且其中一个超过最大长度时,它仍会尝试上传超出范围的文件(即使我不调用data.submit()
该特定文件)。
我已验证该progress
事件不会针对大(且未提交)文件触发,但服务器最终报告 404.13(请求过滤模块配置为拒绝超过请求内容长度的请求),并且没有其他文件实际提交的被上传。
如何更改使用 jQuery 文件上传控件上传有效文件的方式,但忽略大文件?
这是我的代码...它操作一个模型,该模型通过敲除来显示 UI 元素,因此您不会在下面的代码中看到任何 UI 操作。
$('#fileupload').fileupload({
dataType: 'json',
url: '/Handlers/UploadHandler.ashx',
progress: function (e, data) {
console.log(data.context);
var progress = parseInt(data.loaded / data.total * 100, 10);
var file = fileUploadDataModel.files()[data.context];
file.percentComplete(progress);
},
add: function (e, data) {
$.each(data.files, function (index, file) {
var fileModel = new FileModel(file.name, file.size);
fileUploadDataModel.files.push(fileModel);
data.context = fileUploadDataModel.files().length - 1;
if (file.size > opts.maxFileSize) {
fileModel.errorMessage('{0} ({1}) exceeds maximum size -- rejected'.format(file.name, friendlyBytes(file.size)));
fileModel.percentComplete(0);
}
else data.submit();
});
},
done: function (e, data) {
var file = fileUploadDataModel.files()[data.context];
file.percentComplete(100);
},
singleFileUploads: false,
});