Ausgabe
Ich habe ein NestJs- Projekt in meinem Controller. Ich akzeptiere eine Express.Multer.File , aber ich muss sie an einen anderen Server senden. Wie kann ich es in Blob konvertieren, um es an FormData zu übergeben ?
#action in my controller
@Post('/upload')
@UseInterceptors(FileInterceptor('avatar'))
async uploadUserProfileAvatar(@UploadedFile() file: Express.Multer.File){
console.log(file)
let blob = new Blob(file.mimetype)
let formData = new FormData()
//can't set because file is not Blob
formData.append('file',file)
let request$ = this.httpService.post('http://test_server/file',formData,{headers:{
'Content-Type':'multipart/form-data'
}}).pipe(
map(response => response.data)
)
request$.subscribe( response => {
console.log(response)
return response
})
}
Ich bin für jede Antwort dankbar!
BEARBEITEN:
Danke nochmal für deine Hilfe! Als Ergebnis gelang es mir, den Code erfolgreich auf diese Weise zu senden:
@Post('/upload')
@UseInterceptors(FileInterceptor('avatar'))
async uploadUserProfileAvatar(@UploadedFile() file: Express.Multer.File){
const FormData = require('form-data');
const formData = new FormData();
formData.append('file', Buffer.from(file.buffer) , file.originalname);
let request$ = this.httpService.post('http://nginx_files/file',formData,{headers:formData.getHeaders()}).pipe(
map(response => response.data)
)
request$.subscribe( response => {
console.log(response)
return response
})
}
Lösung
Verwenden Sie formdata
das Paket wie folgt:
const FormData = require('form-data');
const formData = new FormData();
formData.append('file', fileContent, 'file_name.ext');
let request$ = this.httpService.post('http://test_server/file',
formData,
{ headers: formData.getHeaders() }
).pipe(
map(response => response.data)
)
Beantwortet von – Anatoly
Antwort geprüft von – Pedro (FixError Volunteer)