Unable to post File data in Safari 10 with a XHR POST request
https://bugs.webkit.org/show_bug.cgi?id=165081
Summary Unable to post File data in Safari 10 with a XHR POST request
bede.bignell
Reported 2016-11-27 00:34:24 PST
Uploading an image (from a dataUrl format) using an XHR request appears to fail on iOS (10.0.2+), other browsers are working: the latest Chrome (54.0.2840.71), Firefox (50.0). The request seems to be constructed correctly in JS, but there is no actual data attached to the request. var dataUrl = ""; // create base64 encoded version of image let parts = dataUrl.split(','); let mime = parts[0].match(/:(.*?);/)[1]; let bstr = atob(parts[1]); let n = bstr.length; let u8arr = new Uint8Array(n); while (n--) { u8arr[n] = bstr.charCodeAt(n); } let blob = new window.Blob([u8arr], {type: mime}); file = new window.File([blob], file.name); // create formdata for uploading let data = new FormData(); data.append('file', file, file.name); // send the post request var xhr = new XMLHttpRequest; xhr.onload = function (oEvent) { // Uploaded. if ( oEvent.target.status == '200') { console.log('upload with XHR success'); } else { console.log('upload with XHR error'); } }; xhr.open("POST", '/upload-endpoint', false); xhr.send(data);
Attachments
test case (1.16 KB, text/html)
2017-05-10 23:34 PDT, koichiro.sobue+webkit
no flags
Alexey Proskuryakov
Comment 1 2016-11-29 12:21:50 PST
Weird! Probably a general issue with Files created from Blobs, as there doesn't seem to be anything XHR specific here. As a workaround, you can create the FormData with a Blob instead of a File: data.append('file', blob, name);
Radar WebKit Bug Importer
Comment 2 2016-12-01 12:35:28 PST
koichiro.sobue+webkit
Comment 3 2017-05-10 23:31:32 PDT
When File object is created using window.File constructor, m_path won't be set. https://github.com/WebKit/webkit/blob/master/Source/WebCore/fileapi/File.cpp#L74 This causes the following if statement to evaluate false, resulting the file being ignored. https://github.com/WebKit/webkit/blob/master/Source/WebCore/platform/network/FormData.cpp#L226 I don't think this checking is necessary.
koichiro.sobue+webkit
Comment 4 2017-05-10 23:34:29 PDT
Created attachment 309693 [details] test case
Note You need to log in before you can comment on or make changes to this bug.