Загрузите объект JSON (информация о пользователе) и несколько изображений с одним запросом. Угловой + пружинный башмак
Spring Rest Controller
@PostMapping(consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
public ResponseEntity<PersonDTO> createPerson(@RequestParam("user") User personDTO, @RequestParam("file") MultipartFile[] file){
return new ResponseEntity<>(null, responseHeaders, HttpStatus.OK);
}
Угловой сервис
createPerson(personClass : User, files : File[]): Observable<HttpEvent<{}>>{
let formdata: FormData = new FormData();
//Get Cities
var obj = JSON.parse(JSON.stringify(personClass.city));
var myObj = {avatar:personClass.avatar,username:personClass.username , gender:personClass.gender, country:personClass.country, city:obj.code, about:personClass.about};
//get upload images
let fileCount: number = files.length;
if (fileCount > 0) { // a file was selected
for (let i = 0; i < fileCount; i++) {
formdata.append('file', files[i]);
}
}
const userBlob = new Blob([myObj],{ type: "application/json"});
// User object to FormData
formdata.append('user',JSON.stringify(myObj));
return this.http.post(`${this.webServiceEndpoint}/person`,formdata)
.map(res => res.json() )
.catch(this.handleError);
}
Обратите внимание: если в Spring rest controller я меняю тип параметра User на String, он работает, и несколько файлов могут читать из Spring rest controller.
Весенний отдых: пользовательский объект
{"avatar":"","username":"","gender":"male","country":[],"about":"sdf"}
Вопрос: Как отправить запрос из Angular, чтобы в Spring я мог получить User Object вместо String.
1 ответ
public ResponseEntity<PersonDTO> createPerson(@RequestParam("user") User personDTO, @RequestParam("file") MultipartFile[] file){
должен быть изменен на
public ResponseEntity<PersonDTO> createPerson(@RequestPart("file") MultipartFile[] file, @RequestPart("user") User personDTO){
чтобы весенняя загрузка знала, что эти параметры будут отдельными частями.