I'm trying to upload a file as MIME/multipart via AngularJS 1.6.4 and then send it off to an ASP.Net WebAPI. I have referenced a sample project that uses version 1.3.1, where the following works:
var formData = new FormData();
angular.forEach(photos, function (photo) {
formData.append(photo.name, photo);
});
return photoManagerClient.save(formData)
.$promise
.then(function (result) {
if (result && result.photos) {
result.photos.forEach(function (photo) {
if (!photoExists(photo.name)) {
service.photos.push(photo);
}
});
}
.
.
.
function photoManagerClient($resource) {
return $resource("api/photo/:fileName",
{ id: "@fileName" },
{
'save': { method: 'POST', transformRequest: angular.identity, headers: { 'Content-Type': undefined } }
});
}
I can't get this to work using 1.6.4 and I can't find the reason. The MIME/multipart header isn't there with 1.6.4, so I have been reading the bytes directly from the content, and yet I can't get the filename in this way.
It's obvious that the FormData is actually making it across because I can access the bytes in the request.
I have seen other answers/docs advise adding a transformRequest function because otherwise the Content-Type defaults to JSON. But when I do this, that code does not execute so the file is missing from the request on the server side.
I'm a bit lost here and was hoping there was an obvious reason for this difference between 1.3.1 and 1.6.4 that someone could point me toward.
Edit to add request headers:
Accept:application/json, text/plain, */*
Accept-Encoding:gzip, deflate, br
Accept-Language:en-US,en;q=0.9
Connection:keep-alive
Content-Length:31761
Content-Type:application/json;charset=utf-8
Host:localhost:40981
Origin:http://localhost:51609
Referer:http://localhost:51609/app/
User-Agent:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3266.0 Safari/537.36
Check the header request
at Network
in dev-tools, maybe it useful.
If is not work, paste the header reuqest
maybe can provide more information.