Передача типа входного файла через ajax в php не работает - PullRequest
0 голосов
/ 29 июня 2018

У меня есть эта функция для получения значений из формы

$("button[name='createimport']").click(function() {
var fd = new FormData();
var files = $('#xsfile')[0].files[0];
fd.append('file',files);

var batchid = $("input[name='batchid']").val();
var yrstart = $("input[name='yrstart']").val();
var yrend = $("input[name='yrend']").val();

$.ajax({
    url:"fetch_import.php",
    method:"POST",
    data: { batchid : batchid, yrstart: yrstart, yrend: yrend, fd},
    success: function (data) {
        //show success result div
        if(data)
        {
            showSuccess();
        }
        else
        {
            showFailure();
        }

    },
    error: function () {
        //show failure result div
        showFailure();
        }
}); 
});

и php-код:

enter code here$bcid =  $_POST['batchid'];
$yrs =  $_POST['yrstart'];
$yrg =  $_POST['yrend'];

/* Getting file name */
$filename = $_FILES['file']['name'];

/* Location */
$location = "upload/".$filename;
$FileType = pathinfo($location,PATHINFO_EXTENSION);
move_uploaded_file($_FILES['file']['tmp_name'],$location);

передача файла не работает. Я искал это, но все еще не работает для меня, я думаю, я пойму, как это будет работать. Любая идея? Tyia

1 Ответ

0 голосов
/ 29 июня 2018

Вы должны добавить свои поля к fd и просто использовать это как параметр данных в $.ajax:

$("button[name='createimport']").click(function() {
    var fd = new FormData();
    var files = $('#xsfile')[0].files[0];
    fd.append('file',files);

    fd.append('batchid', $("input[name='batchid']").val());
    fd.append('yrstart', $("input[name='yrstart']").val());
    fd.append('yrend', $("input[name='yrend']").val());

    $.ajax({
        url:"fetch_import.php",
        method:"POST",
        data: fd,
        success: function (data) {
            //show success result div
            if(data)
            {
                showSuccess();
            }
            else
            {
                showFailure();
            }

        },
        error: function () {
            //show failure result div
            showFailure();
            }
    }); 
});
...