2010-09-17 69 views
2

我正在写一个Grails应用程序并遇到一个奇怪的问题。当点击页面上的提交按钮时,相关联的操作会快速连续调用两次。这会导致所有事情都崩溃。有没有其他人看过这个问题?下面是我的代码:Grails操作被调用两次。帮帮我!

从GSP页面:

<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; 
} 

输出:

!!!!!! !!!!!!!!!!!!!!!!!!!!!!
Sat Sep 17 00:00:00 EDT 1994
时间1284757543744
****************************
!! !!!!!!!!!!!!!!!!!!!!!!!!!!
null
时间1284757544091
****************************
2010-09-17 17:05:44,100 [ HTTP-8080-2] ERROR errors.GrailsExceptionResolver - 空
显示java.lang.NullPointerException

你可以看到第一次调用两次后的几毫秒的动作将被调用。系统失败,因为在第二次调用时,日期对象为空。有任何想法吗?谢谢!

回答

0

你已经解决了吗?你有没有尝试改变从节目中的行动来保存?

<g:form method="post" action="save"> 

代替

<g:form method="post" action="show"> 

,并且该方法作为保存的名称。在post方法中看到“显示”动作是很奇怪的。也许Grails在幕后做了一些事情,因为Grails根据惯例做了很多事情,你甚至可能不知道!

+1

我想通了,谢谢你的评论!事实证明,当呈现的内容包含诸如属性为空的属性时,浏览器会再次请求该信息。由于对象仅存在于第一次通话的情况下,所以第二次通话被轰炸。换句话说,它与尝试将某个XML呈现给正在呈现的页面有关。 – Quad64Bit 2010-09-29 20:13:10