![](/img/trans.png)
[英]Send Ajax request to get json data from json file with pure javascript
[英]Send file with JSON Data in ajax request
我想將圖像文件發送到控制器,但HttpPostedFileBase
為空,我在JSON.stringify({})
之外輸入image: image
但沒有工作。 另外,我更改contentType
並查看此問題並使用它作為答案,但我的問題未解決。
var file_data = $("#Image").prop("files")[0];
var image = new FormData();
image.append("file", file_data);
$.ajax({
url: '@postUrl',
method: "POST",
contentType: 'application/json',
data:
JSON.stringify({
image: image,
isFirst : true,
ExternalProjects: ExternalProjects,
// more data
})
})
您沒有將FormData
實例放在對象中並對其進行字符串化。 你做相反的事情:把你的文件和其他數據放在 FormData 實例中。
正如您鏈接的答案所說,將contentType
和processData
選項更改為 false 以告訴 jQuery 不要處理數據本身。
var file_data = $("#Image").prop("files")[0];
var fd = new FormData();
fd.append("file", file_data);
fd.append("isFirst", true);
fd.append("ExternalProjects", ExternalProjects);
$.ajax({
url: '@postUrl',
method: "POST",
contentType: false,
processData: false,
data:fd
});
您的數據將位於各自的字段中: file
、 isFirst
和ExternalProjects
我為自己發現的最好的寺院:
export const convertDataToFormDataFormat = (data, formData = null, keyPrefix = '') => {
if (!data) {
return null;
}
let currentFormData = formData || new FormData();
if (Array.isArray(data)) {
data.forEach((entry, i) => {
currentFormData = convertDataToFormDataFormat(entry, currentFormData, `${keyPrefix}[${i}].`);
});
return currentFormData;
}
if (data) {
Object.entries(data).forEach(([key, value]) => {
const fullKey = keyPrefix + key;
if (value === undefined || value === null) {
currentFormData.append(fullKey, '');
} else if (value.constructor === File) {
currentFormData.append(fullKey, value);
} else if (Array.isArray(value)) {
currentFormData = convertDataToFormDataFormat(value, currentFormData, `${fullKey}`);
} else if (value === Object(value)) {
currentFormData = convertDataToFormDataFormat(value, currentFormData, `${fullKey}.`);
} else {
currentFormData.append(fullKey, value);
}
});
}
return currentFormData;
};
轉換成這樣的:
fieild.test1= 'test';
fieild.test2= 'test';
field.arr[0].testField1 = 'testField ';
field.arr[0].testField2 = 'testField ';
field.arr[1].testField = 'testField ';
field.arr[1].testField2 = 'testField ';
field.arr[2].testField = 'testField ';
field.arr[2].testField2 = 'testField ';
適用於 asp.net core 2.0:
[HttpPost]
public async Task<IActionResult> CreateExpense([FromForm] List<SomeModelWithIFormFileField> dto)
{
....
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.