У меня есть вызов ajax, где я использовал jQuery.ajax(), чтобы сделать запрос к действию mvc. Все это прекрасно работало. Однако из-за некоторых форм, имеющих файловый контроль, я изменил его с помощью jQuery.ajax() на использование XMLHttpRequest для его отправки с использованием API файлов HTML5.
После внесения этого изменения метод действия MVC больше не рассматривает его как запрос ajax. Используя Fiddler2, я заметил, что он больше не добавляет запрос X-Requested-With: XMLHttpRequest, и я предполагаю, что это проблема.
Форма, которую я пытаюсь отправить, не содержит в нее ввода файла, только нормальные текстовые поля и т.д., но я пытался сохранить общий метод для решения обоих. Ниже приведен код, который я использую для отправки запроса ajax:
// get the edit tender form
var $Form = $Button.closest('form');
var Url = $Form.attr('action');
var AjaxRequestObject = new XMLHttpRequest();
var FormDataToSend = new FormData();
$Form.find(':input').each(function () {
if ($(this).is('input[type="file"]')) {
var files = $(this)[0].files;
if (files.length > 0) {
FormDataToSend.append(this.name, files[0]);
}
} else {
FormDataToSend.append(this.name, $(this).val());
}
});
AjaxRequestObject.open('POST', Url, true);
AjaxRequestObject.onreadystatechange = function () {
if (AjaxRequestObject.readyState == 4) {
// handle response.
if (AjaxRequestObject.status == 200) {
if (!AjaxErrorExists(AjaxRequestObject.responseText, )) {
alert("success");
console.log(AjaxRequestObject.responseText);
}
else {
alert('failure');
}
}
else {
alert('failure');
}
}
};
AjaxRequestObject.send(FormDataToSend);
Этот код был предоставлен после проблемы, с которой Дарин Димитров предоставил решение, поэтому я мог отправлять входные данные файла с помощью ajax.
Любые идеи, почему этот запрос не отправил заголовок для вызова ajax?