【发布时间】:2017-10-23 16:52:26
【问题描述】:
我正在尝试使用 Angular2 和 SpringBoot 完成我的文件上传功能。我可以证明我的文件上传的 java 代码工作正常,因为我已经使用 Postman 成功测试了它。
但是,在从 Angular2 前端发送文件时,我收到的 HTTP 400 响应为 Required request part 'file' is not present。
这就是我从 Angular2 发送 POST 请求的方式。
savePhoto(photoToSave: File) {
let formData: FormData = new FormData();
formData.append('file', photoToSave);
// this will be used to add headers to the requests conditionally later using Custom Request Options
this._globals.setRequestFrom("save-photo");
let savedPath = this._http
.post(this._endpointUrl + "save-photo", formData)
.map(
res => {
return res.json();
}
)
.catch(handleError);
return savedPath;
}
请注意,我编写了一个扩展BaseRequestOptions 的CustomRequestOptions 类,以便附加授权标头和内容类型标头。内容类型标头将有条件地添加。
下面是代码。
@Injectable()
export class CustomRequestOptions extends BaseRequestOptions {
constructor(private _globals: Globals) {
super();
this.headers.set('X-Requested-By', 'Angular 2');
this.headers.append('virglk', "vigamage");
}
merge(options?: RequestOptionsArgs): RequestOptions {
var newOptions = super.merge(options);
let hdr = this._globals.getAuthorization();
newOptions.headers.set("Authorization", hdr);
if(this._globals.getRequestFrom() != "save-photo"){
newOptions.headers.set('Content-Type', 'application/json');
}else{
//request coming from save photo
console.log("request coming from save photo");
}
return newOptions;
}
}
此条件标题附加工作正常。这样做的目的是如果我在每个请求中添加'Content-Type', 'application/json' 标头,Spring 控制器中的文件上传方法将不接受它。 (返回 http 415)
一切似乎都很好。但我得到Required request part 'file' is not present 错误响应。这是为什么?我正在将该参数添加到表单数据中。
let formData: FormData = new FormData();
formData.append('file', photoToSave);
这是Spring Controller方法供大家参考。
@RequestMapping(method = RequestMethod.POST, value = "/tender/save-new/save-photo", consumes = {"multipart/form-data"})
public ResponseEntity<?> uploadPhoto(@RequestParam("file") MultipartFile file){
if (file.isEmpty()) {
ErrorResponse errorResponse = new ErrorResponse();
errorResponse.setMessage("DEBUG: Attached file is empty");
return new ResponseEntity<ErrorResponse>(errorResponse, HttpStatus.NOT_FOUND);
}
String returnPath = null;
try {
// upload stuff
} catch (IOException e) {
ErrorResponse errorResponse = new ErrorResponse();
errorResponse.setMessage(e.getMessage());
return new ResponseEntity<ErrorResponse> (errorResponse, HttpStatus.INTERNAL_SERVER_ERROR);
}
return new ResponseEntity<String>(returnPath, HttpStatus.OK);
}
EDIT - 添加浏览器捕获的请求的负载
如您所见,参数“文件”在那里可用。
【问题讨论】:
-
有完全相同的问题。如果你解决了问题,请告诉我
-
嗨,刚刚想通了。问题在于从 DOM 获取输入对象。服务器代码没有问题。当您控制台记录输入文件时,它会打印吗?让我知道
-
谢谢兄弟!你的提示奏效了!我将文件数组而不是单个数组传递给服务器!谢谢!!
-
很高兴听到这个消息 :)
-
您能发布有效的解决方案吗?我在挣扎
标签: spring angular http file-upload spring-boot