使用 icepush 检票口集成并尝试从另一个类调用'push()'时"No RequestCycle is currently set!"例外



好了。这是我的第一个wicket应用程序,我正在尝试使用pushpanel示例集成icepush。

我想做的是通过调用另一个类的updatePanel(String-content)方法将更新推送到面板。

这是代码。

在我的扩展PushPanel中,我有:

public AsyncCommsPanel(String id) {
    super(id);
    this.setOutputMarkupId(true);
    ajaxForm = new Form("ajaxForm");
    ajaxForm.setOutputMarkupId(true);
    ajaxForm.add(textStore = new Label("textStore",""));
    ajaxForm.add(new AjaxButton("updateButton") {
        @Override
        protected void onSubmit(AjaxRequestTarget target, Form form) {
            System.out.println("Update button pressed!");
            /* CODE TO PULL NEW DATA FROM ELSEWHERE */
            /* UPDATE TAKES TIME SO HAS ITS OWN CALLBACK */
        }
        @Override
        protected void onError(AjaxRequestTarget target, Form<?> form) {
            System.out.println("Update button error.");
        }
    });
    add(ajaxForm);
}
@Override
protected void pushCallback(AjaxRequestTarget target) {
    target.add(ajaxForm);
}
public void updatePanel(String updateString) {
    /* THIS METHOD SHOULD ALLOW THE PANEL TO BE UPDATED FROM ELSEWHERE */
    if (textStore != null) ajaxForm.remove(textStore);
    ajaxForm.add(textStore = new Label("textStore", updateString));
    push();
}

当我尝试从数据采集程序的回调方法调用"updatePanel"方法时,我会得到以下异常:

ERROR (SelectorManager.run):  org.apache.wicket.WicketRuntimeException: No RequestCycle is currently set!
at org.apache.wicket.Component.getRequest(Component.java:1831)
at org.apache.wicket.markup.html.WebPage.dirty(WebPage.java:315)
at org.apache.wicket.Page.dirty(Page.java:288)
at org.apache.wicket.Page.componentRemoved(Page.java:948)
at org.apache.wicket.MarkupContainer.removedComponent(MarkupContainer.java:1422)
at org.apache.wicket.MarkupContainer.remove(MarkupContainer.java:612)
at uk.ac.warwick.collabtex.AsyncCommsPanel.updatePanel(AsyncCommsPanel.java:107)
at uk.ac.warwick.collabtex.Editor$1.updateSuccess(Editor.java:98)

欢迎来到异步世界:-)ThreadLocals(应用程序、会话和ThreadLocal)仅在处理http请求线程(也称为工作线程)期间可用。因此有两个问题:1)启动自己的线程会丢失ThreadLocal,2)即使导出了它们,当作业完成时,响应也有可能已经关闭。我不确定IcePush是如何工作的,但我认为这是最好的选择-提交任务,在应用程序中保留对它的引用(例如Map),然后启动ajax计时器行为,定期询问futureTask.isDone(),当它返回true时,您需要更改层次结构(我在stacktrace中看到对MarkupContainer#remove()的调用)。

最新更新