Fre*_*red 8 jquery multipartform-data asp.net-core
我一直试图让这个工作,但无济于事。
我想要做的是使用 JQuery AJAX 上传一组 FormData 图像和附件。
我不断收到错误消息:“超出多部分正文长度限制 16384”
我在 SO 上发现了另一个类似的问题: Multipart body length limit exceeded 异常
如果这里有人可以帮助我或为我指明方向,那将不胜感激。我这边快午夜了,我要放弃了:(。
我正在使用 ASP.NET Core 1.1。
这是我的javascript:
let data = new FormData();
data.enctype = "multipart/form-data";
let file = $("#imgItem_image-upload-file")[0].files[0];
data.append("image|" + file.name, file); //Works fine if alone.
//Does not work, causes error on server side.
for (var i = 0; i < objItem.Attachments[0].length; i++) {
let attFile = objItem.Attachments[0][i].File;
console.log(attFile);
data.append("attachment|" + attFile.name, attFile);
}
data.append("Category", objItem.Category);
data.append("NewCategory", objItem.NewCategory);
data.append("Name", objItem.Name);
data.append("IdentificationType", objItem.IdentificationType);
data.append("SerialNumber", objItem.SerialNumber);
data.append("IMEI", objItem.IMEI);
data.append("EngineNumber", objItem.EngineNumber);
data.append("MASNumber", objItem.MASNumber);
data.append("NumberPlate", objItem.NumberPlate);
data.append("VINNumber", objItem.VINNumber);
data.append("Description", objItem.Description);
$.ajax({
url: "http://localhost:7001/api/AddPersonalItem",
type: "POST",
data: data,
//dataType: "json",
//headers: { 'Content-Type': false },
//contentType: false,
contentType: false, //'multipart/form-data'
processData: false,
// headers: {
// 'Accept': 'application/json',
// 'Content-Type': 'application/json'
// },
success: function (response) {
},
error: function(jqXHR, textStatus, errorThrown) {
console.log(textStatus, errorThrown);
}
});
Run Code Online (Sandbox Code Playgroud)
我还将它添加到我的 Startup.js 文件中:
public void ConfigureServices(IServiceCollection services)
{
// Add framework services.
services.AddMvc();
//Multipart
services.Configure<FormOptions>(x =>
{
x.MultipartBodyLengthLimit = 60000000;
});
}
Run Code Online (Sandbox Code Playgroud)
这是我的 API 控制器的代码:
public ServiceCallResponse AddPersonalItem()
{
ItemObject io = new ItemObject();
io.Attachments = new List<Attachment>();
io.Image = new Image();
//Get files.
foreach (IFormFile file in Request.Form.Files)
{
//The file name also states what type of object this is.
string type = file.Name.Split('|')[0];
string name = file.Name.Split('|')[1];
StreamReader reader = new StreamReader(file.OpenReadStream());
byte[] bytes = Encoding.Unicode.GetBytes(reader.ReadToEnd());
string base64 = Convert.ToBase64String(bytes);
switch (type.ToLower().Trim())
{
case "attachment":
Attachment a = new Attachment();
a.Name = name;
a.Base64 = base64;
io.Attachments.Add(a);
break;
case "image":
io.Image.Name = name;
io.Image.Base64 = base64;
break;
}
}
}
Run Code Online (Sandbox Code Playgroud)
即使在增加多部分主体长度后,我仍然收到完全相同的错误。
错误发生在:
foreach(Request.Form.Files 中的 IFormFile 文件)
如果我对此不够清楚,请询问,我会尽力详细说明!:)
就我而言,解决方案是增加 MemoryBufferThreshold。
services.Configure<FormOptions>(options =>
{
options.MemoryBufferThreshold = Int32.MaxValue;
});
Run Code Online (Sandbox Code Playgroud)
小智 5
我得到了异常,我发现我的客户端有一个不正确的 HTTP 标头"content-type"。将curl与错误的输入类型一起使用curl试图将 POST Body 中的整个文件作为文本发送,这不是一个好举动:-)
curl示例:这失败了:
curl --request POST \
--url https://stuff.net/api/storage \
--header 'authorization: bearer MY_ACCESS_TOKEN' \
--header 'cache-control: no-cache' \
--header 'content-type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW' \
--form MyfileName=b72871d79c81 \
--form file=@nature-sky-twilight.jpg \
--form MyfileId=9401c94db46c
Run Code Online (Sandbox Code Playgroud)
这有效:
curl --request POST \
--url https://stuff.net/api/storage \
--header 'authorization: bearer MY_ACCESS_TOKEN' \
--header 'cache-control: no-cache' \
--form MyfileName=b72871d79c81 \
--form file=@nature-sky-twilight.jpg \
--form MyfileId=9401c94db46c
Run Code Online (Sandbox Code Playgroud)
您还需要增加值长度限制。默认值是 4MB。
services.Configure<FormOptions>(options =>
{
options.ValueCountLimit = 10; //default 1024
options.ValueLengthLimit = int.MaxValue; //not recommended value
options.MultipartBodyLengthLimit = long.MaxValue; //not recommended value
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13070 次 |
| 最近记录: |