Multipart Http Response
Solution 1:
You can serve the response as multipart/form-data
and use Response.formData()
to read response at client
fetch("/path/to/server", {method:"POST", body:formData})
.then(response => response.formData())
.then(fd => {
for (let [key, prop] of fd) {
console.log(key, prop)
}
})
let fd = newFormData();
fd.append("json", JSON.stringify({
file: "image"
}));
fetch("")
.then(response => response.blob())
.then(blob => {
fd.append("file", blob);
newResponse(fd)
.formData()
.then(formData => {
for (let [key, data] of formData) {
console.log(key, data)
}
})
})
Solution 2:
If you are going for a multipart format, I don't think there's anything inherently wrong with using the exact same format both during upload (POST/PUT) and retrieval (GET).
I think there's definitely an elegance in using the same on-wire format in both directions when working with HTTP.
However, if you want to send form-data during PUT/POST and JSON back using GET, then I would start questioning whether this is the right thing to do.
multipart gets annoying for clients if they just want to display the image. Have you considered just using different endpoints; one for the image and one for it's meta-data? What reason do you have to want to combine them into a single resource?
Alternatively, you could also attempt to embed the information in the image. JPEG for instance allows custom data to be added using EXIF. At least you preserve the ability to just open the image directly.
However, I will conclude with saying that multipart/mixed
is appropriate if you just want to embed an image + a json object, but bear in mind:
- It's probably a bit inconvenient for consumption
- It's also a bit unusual
- I'm fairly sure that multipart encoding will require you to encode your image in some 7bit encoding, which will inherently cause the request size to blow up quite a bit.
Post a Comment for "Multipart Http Response"