I’ve got a problem sending a file to a serverside PHP-script using jQuery’s ajax function.
It’s possible to get the File-List with $('#fileinput').attr('files') but how is it possible to send this Data to the server? The resulting array ($_POST) on the server side php-script is 0 (NULL) when using the file-input.
I know it is possible (though I didn’t find any jQuery solutions until now, only Prototye code (http://webreflection.blogspot.com/2009/03/safari-4-multiple-upload-with-progress.html)).
This seems to be relatively new, so please do not mention file upload would be impossible via XHR/Ajax, because it’s definitely working.
I need the functionality in Safari 5, FF and Chrome would be nice but are not essential.
My code for now is:
$.ajax({
url: 'php/upload.php',
data: $('#file').attr('files'),
cache: false,
contentType: 'multipart/form-data',
processData: false,
type: 'POST',
success: function(data){
alert(data);
}
});
Starting with Safari 5/Firefox 4, it’s easiest to use the
FormDataclass:So now you have a
FormDataobject, ready to be sent along with the XMLHttpRequest.It’s imperative that you set the
contentTypeoption tofalse, forcing jQuery not to add aContent-Typeheader for you, otherwise, the boundary string will be missing from it.Also, you must leave the
processDataflag set to false, otherwise, jQuery will try to convert yourFormDatainto a string, which will fail.You may now retrieve the file in PHP using:
(There is only one file,
file-0, unless you specified themultipleattribute on your file input, in which case, the numbers will increment with each file.)Using the FormData emulation for older browsers
Create FormData from an existing form
Instead of manually iterating the files, the FormData object can also be created with the contents of an existing form object:
Use a PHP native array instead of a counter
Just name your file elements the same and end the name in brackets:
$_FILES['file']will then be an array containing the file upload fields for every file uploaded. I actually recommend this over my initial solution as it’s simpler to iterate over.