Ajax 请求中的文件未随 FormData 一起发送
File not sending with FormData in Ajax request
我有一个 ajax 请求正在发送一个文件和一些其他信息。除文件外的所有内容都是正确的值,并且文件始终为空。我不明白为什么。
这是我在表格中包含的输入:
<input type="file" id="file" runat="server"/>
单击按钮时,它会调用此函数:
function ButtonClick() {
var file = document.getElementById('file').files[0]; // correctly gets the file
var formData = new FormData();
formData.append('key1', 'val1');
formData.append('key2', 'val2');
formData.append('file', file, file.name);
$.ajax({
cache: false,
data: formData,
dataType: 'json',
processData: false,
contentType: false,
success: function (data, textStatus, jqXHR) { closeWindow(); },
timeout: 30000,
type: 'POST',
url: '<%= ResolveClientUrl("~/api/Example/ExampleUrl") %>'
});
}
当我在服务器端收到请求时,我得到以下值:
var key1= HttpContext.Current.Request.Form["key1"]); // returns "val1"
var key2= HttpContext.Current.Request.Form["key2"]); // returns "val2"
var file= HttpContext.Current.Request.Form["file"]); // returns "null"
当我查看 HttpContext.Current.Request.Form
时,“文件”根本不在请求中。
文件应该可以通过
访问
HttpContext.Current.Request.Files["file"]
我有一个 ajax 请求正在发送一个文件和一些其他信息。除文件外的所有内容都是正确的值,并且文件始终为空。我不明白为什么。
这是我在表格中包含的输入:
<input type="file" id="file" runat="server"/>
单击按钮时,它会调用此函数:
function ButtonClick() {
var file = document.getElementById('file').files[0]; // correctly gets the file
var formData = new FormData();
formData.append('key1', 'val1');
formData.append('key2', 'val2');
formData.append('file', file, file.name);
$.ajax({
cache: false,
data: formData,
dataType: 'json',
processData: false,
contentType: false,
success: function (data, textStatus, jqXHR) { closeWindow(); },
timeout: 30000,
type: 'POST',
url: '<%= ResolveClientUrl("~/api/Example/ExampleUrl") %>'
});
}
当我在服务器端收到请求时,我得到以下值:
var key1= HttpContext.Current.Request.Form["key1"]); // returns "val1"
var key2= HttpContext.Current.Request.Form["key2"]); // returns "val2"
var file= HttpContext.Current.Request.Form["file"]); // returns "null"
当我查看 HttpContext.Current.Request.Form
时,“文件”根本不在请求中。
文件应该可以通过
访问HttpContext.Current.Request.Files["file"]