Проблема
Я пытаюсь загрузить изображение с angular HttpClient
в API Content-Type: multipart/form-data
(angular v4 +). Поддерживается ли это? Как это сделать?
Загрузка выполняется с помощью XMLHttpRequest
при использовании модуля, например ng2-fancy-image-uploader
. Я бы предпочел использовать собственный метод с HttpClient
, который я мог бы поместить в службу http вместе с другими методами для доступа к API.
Вот что я пробовал до сих пор:
model.service.ts
import { Injectable } from '@angular/core';
import { HttpClient, HttpHeaders, HttpResponse } from '@angular/common/http';
import 'rxjs/add/operator/toPromise';
@Injectable()
export class ModelService {
constructor(private http: HttpClient) { }
public async updateAvatar(file: File): Promise<void> {
// headers
const headers = new HttpHeaders()
.append('Content-Type', 'multipart/form-data');
const formData: FormData = new FormData();
formData.append('avatar', file, file.name);
const response: HttpResponse = await this.http
.patch('https://example.com/avatar', formData, { headers, observe: 'response' })
.toPromise();
console.log(response.status);
}
}
аватар-uploader.component.ts
import { Component, ElementRef, OnInit, ViewChild } from '@angular/core';
import { ModelService } from './path/to/model.service';
@Component({
selector: 'app-avatar-uploader',
template: '<input type="file" #fileInput (changes)="uploadAvatar()">'
})
export class AvatarUploaderComponent implements OnInit {
@ViewChild('fileInput') fileInputElement: ElementRef;
constructor() { }
ngOnInit() { }
public async uploadAvatar() {
const file: File = this.fileInputElement.nativeElement.files[0];
await this.model.updateAvatar(file);
}
}
Эта версия отправляет запрос на (экспресс) API, но multer
(библиотека для разбора multipart/form-data
запросов) не выполняет синтаксический анализ запроса.
Итак, я предполагаю, что я либо неправильно использую HttpClient
, либо не поддерживает запросы multipart/form-data
.
Я предполагаю, что можно отправить файл с кодировкой base64 или использовать XMLHttpRequest
, но я спрашиваю конкретно о возможности HttpClient
сделать это.