Uploading files using 'fetch' and 'FormData'
Today I learned:
To upload files using
FormData is supported in IE10+.) you must not set
; ; 'file', fileInput.files; ; 'your-upload-url', options;
My API wrapper class has default content type header set to:
So I thought, to upload files using
FormData, it would be enough to override it with:
But alas, it didn't work, server couldn't parse the files I was uploading. I've wasted about half an hour, and then noticed that simple HTML form was setting something else:
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryIn312MOjBWdkffIM
It had this
boundary thing I didn't know anything about.
Then I started searching around the internet and found the solution. To set the correct boundary, I had to explicitly delete
Content-Type header. In that case browser will set the correct
Adding this line solved it.
// Remove 'Content-Type' header to allow browser to add // along with the correct 'boundary' delete options.headers;
boundary and why I had to
delete the header?
Multipart form allow transfer of binary data, therefore server needs a way to know where one field's data ends and where the next one starts.
boundary comes in. It defines a delimiter between fields we are sending in our request (similar to
& for GET requests). You can define it yourself, but it is much easier to let browser do it for you.
------WebKitFormBoundaryIn312MOjBWdkffIM Content-Disposition: form-data; name="file"; filename="my-image.jpg" Content-Type: image/jpeg ------WebKitFormBoundaryIn312MOjBWdkffIM Content-Disposition: form-data; name="field" imagePortrait ------WebKitFormBoundaryIn312MOjBWdkffIM--
That's why I had to manually delete existing header, as it didn't contain boundary, and server was unable to parse the file correctly.