donglun7151 2017-07-09 09:35
浏览 39
已采纳

php ajax文件上传问题

I have a form with various inputs and a file input for uploading 1 image. I am using ajax to post the data. When I submit, I get a console error that says

Undefined index: file

Before making it more secure, I am just trying to get it to actually upload the file.

$target_dir = "../img/";
$target_file = $target_dir . basename($_FILES["file"]["name"]);


if (move_uploaded_file($_FILES["file"]["tmp_name"], $target_dir.$_FILES['file']['name'])) {
    $status = 1;
}

jQuery

$('form').submit(function(e){
    e.preventDefault();
    var form = $( "#form1" ).serialize();
    $(".alert").hide();
    $.ajax({
        url: 'functions/add-news-ajax.php',
        type: 'POST',
        dataType: 'json',
        data: form,

        beforeSend: function() {
            $( "#btn-add" ).hide();
            $( "#loader" ).show();
        },
    })

    .done(function (data) {
        if(!data.success) {
        // validation messages etc.. 
  • 写回答

1条回答 默认 最新

  • douya5331 2017-07-09 14:20
    关注

    I'm afraid you won't be able to send your image through serialize

    var form = $( "#form1" ).serialize();
    

    Try this :

     $('form').submit(function(e){
        e.preventDefault();
        //var form = $( "#form1" ).serialize();
        var form = new FormData($(this));
        (...)
    

    where $this is your form element.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?