我试图上传一个带有spring boot 1.2.0 REST控制器和jQuery ajax的csv文件 . 当我发送帖子请求时,我一直收到415:不支持的媒体类型错误 . 这是我的表格:
<form id="upload_form">
<div id="message">
</div>
<div class="row" id="upload-file-div" style="display: none">
<div class='col-sm-3'>
<label>Select File</label>
<input type="file" name="file">
</div>
<div class='col-sm-3'>
<input type="button" id="file-upload" class="btn btn-primary" value="Upload" onclick="uploadFile()"/>
</div>
</div>
</form>
这是我上传文件的方法:
function uploadFile(){
var response = api.uploadCSV($("#upload_form"));
if(response.status === 'OK'){
$("#message").css('color', 'green');
}else{
$("#message").css('color', 'red');
}
$("#message").html(response.message);
}
这是实际的jQuery POST:
upload: function (url, form, ignoreSuccess) {
var response = null;
if (!this.validate(form)) {
var array = form.serializeArray();
alert(array);
var formData = new FormData(form);
console.warn(formData);
$.ajax({
type: "POST",
url: API_PROXY + url,
data: formData,
cache: false,
contentType: false,
processData: false,
async: false,
beforeSend: function (request) {
if (api.getSession() !== null) {
request.setRequestHeader("Authorization", "Bearer " + api.getSession().bearer);
}
},
success: function () {}
}).done(function (msg) {
response = msg;
});
}
return response;
}
以下是我的控制器:
@RequestMapping(consumes = "multipart/form-data", method = RequestMethod.POST,
value = "/upload/twitter", produces = MediaType.APPLICATION_JSON_VALUE)
public Response<String> uploadCsv(CsvUploadModel form) {
//码
}
我在Spring启动类中注释了MultipartConfigElement和MultipartResolver . 我正在使用spring boot 1.2.0 . 当我使用PostMan(chrome扩展名)发送帖子请求时,它按预期工作 . 但是,当我尝试上面的jquery代码时,它会不断抛出不支持的媒体类型错误 .
以下我尝试过的事情:
-
围绕内容类型 Headers ,最后我将contentType设置为false .
-
使用form.serializeArray(),迭代它并将各个元素追加到formData中 .
-
发送表单对象而不是表单数据 .
有人可以帮我这个吗?提前致谢 .
1 回答
您可以在
formData
中附加文件输入;需要进行以下更改:这个:
应该:
在你的ajax代码中,这个:
应该:
要么: