Spring Portlet Jquery Ajax发布到Controller
问题内容:
编辑:
开始日期和结束日期是POJO中的joda dateTime,我得到的错误是:
SystemOut O 14:10:16.040 [WebContainer : 2] DEBUG org.springframework.beans.BeanUtils - No property editor [org.joda.time.DateTimeEditor] found for type org.joda.time.DateTime according to 'Editor' suffix convention
...
SystemOut O Error::Failed to convert property value of type 'java.lang.String' to required type 'org.joda.time.DateTime' for property 'startTimestamp'; nested exception is java.lang.IllegalStateException: Cannot convert value of type [java.lang.String] to required type [org.joda.time.DateTime] for property 'startTimestamp': no matching editors or conversion strategy found
我也无法编辑Pojo并添加@DateTimeFormat,因为Pojo是从XSD生成的。我也尝试添加一个customObjectMapper,但是没有任何效果。任何帮助将非常感激。
原始问题:
我正在尝试提交表单并将数据发送到Controller方法。问题是ModelAttribute为空并且没有值。Spring MVC Portlet + Jsp
+ Javascript + Jquery +控制器@ResourceMapping
片段:
JSP:
<portlet:resourceURL id="addNewURL" var="addNewURL">
</portlet:resourceURL>
<form:form id="qmat_new_notification_form" action="#" method="POST" modelAttribute="dataObject">
...
<input type="text" class="date-picker" id="start_date">
...
<input type="submit" value="Save" class="button" onclick="addNew()">
</form:form>
jQuery:
function addNew() {
var dataObject = JSON.stringify({
'startTime': $('#start_date').val(),
'endTime': $('#end_date').val(),
'description': $('#message').val(),
'active': $('#status').val()
});
alert("data::"+dataObject);
$.ajax({
url: "<%=addNewURL%>",
type: 'POST',
contentType: 'application/json',
data: dataObject
}).done(function(json){
alert("Success!");
//more logic
}).fail(function() {
alert("OOPS!");
});
}
控制器:
@ResourceMapping(value = "addNewURL")
public void addNew(@ModelAttribute(value = "dataObject") Obj n,
BindingResult bindingResult, ResourceRequest request, ResourceResponse response, ModelMap model) {
if (!bindingResult.hasErrors()) {
System.out.println("a:::"+n.getDescription());
}
此getDescription为null。另外,如果我使用request.getParameter(“
description”)也为null。我想念什么?请帮忙
问题答案:
您根本不需要使用JSON数据。
首先,避免将dataObject字符串化:
var dataObject = {...}; // no JSON.stringify call
第二,删除,contentType: 'application/json'
因为在这种情况下没有意义。
由于dataObject
是键/值对和default contentType
,因此POST请求将被正确构造。
为了处理单击和提交事件,我建议jQuery单击和提交方法:
$("#submit").click(function (event) {
addNew();
event.preventDefault();
});
$("#submit").submit(function (event) {
addNew();
event.preventDefault();
});
我为这个问题制造了一个小提琴。
请参阅jQuery.ajax文档。