使用Ajax和Spring构建数据以及文件上传
我使用spring,Ajax并尝试将文件与其他数据一起上传
if(form.field_UploadFile != undefined){
formContent.field_UploadFile=$( form.field_UploadFile )[0].files[0];
}
var fields ={};
for(var i=0; i<form.elements.length; i++){
if (form.elements[i].name){
if(form.elements[i].name.substring(0,6)=="field-"){
if(form.elements[i].type=='checkbox'){
if(form.elements[i].checked){
fields[form.elements[i].name]='checked';
}else{
fields[form.elements[i].name]='unchecked';
}
}else{
fields[form.elements[i].name]=form.elements[i].value;
}
}
}
}
$.ajax({
type: "POST",
url: "${pageContext.request.contextPath }/forms/createnocaptcha",
data: formContent,
dataType: "json",
contentType: false,
processData: false,
complete: function (xhr, status) {
$('html, body').animate({ scrollTop: 0 }, 0);
if (status === 'error' || !xhr.responseText) {
//alert("error");
$("#" + messagedivid).addClass("errorMessage");
$("#" + messagedivid).html("Form sunewsbmission error");
}
else {
var data = xhr.responseText;
//$("#" + messagedivid).addClass("successMessage");
//$("#" + messagedivid).html(data);
$("#" + feedbackdivid).addClass("successMessage");
$("#" + feedbackdivid).show();
$("#" + messagedivid).hide();
$(form)[0].reset();
}
调节器
@RequestMapping(value = "/forms/createnocaptcha", method=RequestMethod.POST)
@ResponseBody
public String createPageNoCaptcha( Form formContent, HttpServletRequest request, HttpSession session){
boolean status = false;
如果我把formContent的requestBody然后我得到415不受支持的媒体,如果它被删除,那么表单值为空。
我也可以使用同一控制器的多部分和非多部分。
请指教
谢谢
在发送之前,我们需要将js对象转换为JSON字符串。
像这样在ajax调用中更改数据,
data: JSON.stringify(formContent),
然后使用@RequestBody Form formContent
上一篇: form data along with file upload with Ajax and spring
下一篇: how to upload a multipart file using angular js spring mvc