FormData, как получить или установить границу в multipart/form-data - Angular
У меня есть мини-приложение, где я должен опубликовать данные формы в конечную точку из браузера.
Это мой пост:
var formData = new FormData();
formData.append('blobImage', blob, 'imagem' + (new Date()).getTime());
return $http({
method: 'POST',
url: api + '/url',
data: formData,
headers: {'Content-Type': 'multipart/form-data'}
})
Границы, кажется, добавляются с помощью formData к параметру, однако я не могу заставить его отправлять в заголовке, как мне это сделать?
3 ответа
Ну, кажется, что заголовки ContentType должны быть неопределенными, чтобы добавить правильные границы
Правильный способ - не устанавливать
Content-Type
заголовок.
Пример:
import { http } from '@angular/common/http'
function sendPostData(form: FormData) {
const url = `https://post-url-example.com/submit`;
const options = {
headers: new HttpHeaders({
Authorization: `Bearer auth-token`
})
};
return http.post(url, form, options);
}
Далее добавляем ответ Пабло.
Когда в теле HTTP-запроса есть
FormData
тип, угловой отложит
Content-Type
присвоение заголовка браузеру.
detectContentTypeHeader()
вернется
null
на
FormData
тело запроса и angular не будут устанавливать заголовок запроса.
Это было на
@angular/commons/http/src/xhr.ts
модуль.
// Auto-detect the Content-Type header if one isn't present already.
if (!req.headers.has('Content-Type')) {
const detectedType = req.detectContentTypeHeader();
// Sometimes Content-Type detection fails.
if (detectedType !== null) {
xhr.setRequestHeader('Content-Type', detectedType);
}
}
Обнаружение Content-Type на основе тела запроса:
detectContentTypeHeader(): string|null {
// An empty body has no content type.
if (this.body === null) {
return null;
}
// FormData bodies rely on the browser's content type assignment.
if (isFormData(this.body)) {
return null;
}
// Blobs usually have their own content type. If it doesn't, then
// no type can be inferred.
if (isBlob(this.body)) {
return this.body.type || null;
}
// Array buffers have unknown contents and thus no type can be inferred.
if (isArrayBuffer(this.body)) {
return null;
}
// Technically, strings could be a form of JSON data, but it's safe enough
// to assume they're plain strings.
if (typeof this.body === 'string') {
return 'text/plain';
}
// `HttpUrlEncodedParams` has its own content-type.
if (this.body instanceof HttpParams) {
return 'application/x-www-form-urlencoded;charset=UTF-8';
}
// Arrays, objects, and numbers will be encoded as JSON.
if (typeof this.body === 'object' || typeof this.body === 'number' ||
Array.isArray(this.body)) {
return 'application/json';
}
// No type could be inferred.
return null;
}
Источник:
Если кто-то еще борется с этим... Если вы отправляете FormDate, браузер должен установить для вас тип контента. Чтобы это заработало, я просто установил заголовок enctype для multipart/form-data.
const formData = new FormData();
formData.append('file', file);
let headers = new HttpHeaders();
headers = headers.append('enctype', 'multipart/form-data');
return this.http.post(path, formData, { headers: headers })
У меня также был HttpInterceptor, который устанавливал тип содержимого, поэтому устанавливал его только тогда, когда enctype не был установлен
if (!req.headers.has('enctype')) {
headersConfig['Content-Type'] = 'application/json';
}
надеюсь, это поможет