我使用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;
如果我将requestBody的requestBody放入,那么我将得到415个不受支持的媒体,如果删除它,则表单值为null。
我也可以为多部分和非多部分使用相同的控制器。
请告知
由于
答案 0 :(得分:0)
我们需要在发送之前将js对象转换为JSON字符串。
在这样的ajax调用中更改数据,
data: JSON.stringify(formContent),
然后使用@RequestBody Form formContent
并在Ajax中调用applicationType / json