使用FormData的XHR请求正在POST一个空数组,

时间:2013-12-30 22:55:04

标签: php jquery post xmlhttprequest

我正在制作我自己的this版本。

一切正常,但POSTed值为空。 PHP端的var_dump显示一个空数组。怎么了?

function readfiles(files)
{
    console.log('Reading Files...');
    console.log(files);
    console.log("There are " + files.length + " elements to this array.");

    var formData = new FormData();
    formData.append('file', files[0]);
    console.log(formData);

    console.log("Posting XHR request...");
    // now post a new XHR request
    var xhr = new XMLHttpRequest();
    xhr.open('POST', '/devnull.php',false);

    console.log("sending data...");
    console.log(formData);
    xhr.send(formData);
}

$(document).ready(function(e) {
    $("#holder").on('dragenter',function(e) {
        e.preventDefault();         
        $(this).addClass('hover');
    });
    $("#holder").on('dragleave',function(e) {
        e.preventDefault();         
        $(this).removeClass('hover');
    });
    $("#holder").on('dragover',function(e) {
        e.preventDefault();         
        if(!($("#holder").hasClass('hover')))
            $("#holder").addClass('hover');
    });
    $("#holder").on('drop',function(e) {
        e.preventDefault();
        console.log(e.originalEvent.dataTransfer.files);
        $(this).removeClass('hover');
        readfiles(e.originalEvent.dataTransfer.files)           
        return false;
    });
});

Firebug告诉我数组中有一个元素:

  

FileList {0 = File,length = 1,item = item(),more ...}

但是在我们将它附加到FormData对象之后,我得到了这个:

  

FormData {append = append()}

PHP方面的最终var_dump说明了这一点:

<pre>array(0) {
}
</pre>

1 个答案:

答案 0 :(得分:0)

使用此代码显示文件数据

<?php var_dump($_FILES);?>