我正在编写一个 grails 应用程序并遇到了一个奇怪的问题。单击页面上的提交按钮时,相关的操作会快速连续调用两次。这导致一切都可怕地破裂。有没有其他人见过这个问题?下面是我的代码:
从普惠制页面:
<g:form method="post" action="show">
<h2>All items since...</h2>
<g:datePicker name="startDate" precision="day" value="${new Date()}" /><br/>
<h2>Format</h2>
<g:radio name="feedType" value="RSS1" checked="true"/><span>RSS 1.0</span>
<g:radio name="feedType" value="RSS2"/><span>RSS 2.0</span>
<g:radio name="feedType" value="ATOM"/><span>Atom</span><br/>
<hr />
<h2>Topics</h2>
<g:each in="${list}" var="subscription" status="i">
<g:if test="${i == 0}">
<g:radio name="nodeID" value="subscription.name" checked="true"/><span>${subscription.getPrettyName()}</span><br/>
</g:if>
<g:else>
<g:radio name="nodeID" value="${subscription.name}"/><span>${subscription.getPrettyName()}</span><br/>
</g:else>
</g:each>
<hr/>
<g:submitButton name="getFeedButton" value="Get Feed!" />
从控制器:
def show = {
def nodeID = params.nodeID
def feedType
if(params.feedType.equals("RSS1")){
feedType = FeedType.RSS1;
} else if(params.feedType.equals("RSS2")){
feedType = FeedType.RSS2;
} else{
feedType = FeedType.ATOM;
}
def date = params.startDate
println("!!!!!!!!!!!!!!!!!!!!!!!!!!!!")
println(date)
println("Time "+System.currentTimeMillis());
println("****************************")
def feed = XMPPListenerService.getFeed(date, feedType, nodeID)
response.contentType = "text/xml"
response.outputStream << feed;
}
输出:
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1994 年 9 月 17 日星期六 00:00:00 EDT
时间 1284757543744
******************************
!!!!!!!!!! !!!!!!!!!!!!!!!!!!
空
时间 1284757544091
******************************
2010-09-17 17:05:44,100 [http-8080-2] ERROR 错误.GrailsExceptionResolver - null
java.lang.NullPointerException
您可以看到该操作在第一次调用后的几毫秒内被调用了两次。系统失败,因为在第二次调用时,日期对象为空。有任何想法吗?谢谢!