3

我正在使用 JSF 2.0 中的 PhaseListener。但它的方法每次都会被调用两次。

@Override
public void beforePhase(PhaseEvent arg0) {
    System.out.println("Start Phase "+arg0.getPhaseId()+" here the value "+ ++i +" object "+this);  
}

输出是这样的

Start Phase RESTORE_VIEW 1 here the value 1 object com.phaseListener.MyPhaseListener@cc8c29
Start Phase RESTORE_VIEW 1 here the value 1 object com.phaseListener.MyPhaseListener@106054a

每次它被两个不同的对象调用。

请告诉我,为什么会这样??

4

3 回答 3

5

如果这有助于有人在谷歌上搜索这个问题。

就我而言,我从 Glassfish 3 迁移到 Tomcat 7,我注意到我的自定义阶段侦听器被注册了两次,导致重复的日志条目。

在我的 web.xml 中,我有一个 Glassfish 3 需要的 ConfigureListener,但会在 Tomcat 7 上触发第二次注册:

<listener>
    <listener-class>com.sun.faces.config.ConfigureListener</listener-class>
</listener>

我只是删除了这个块,它解决了这个问题。

于 2014-10-08T14:54:03.543 回答
1

这是因为您在 JSF 应用程序中注册了两次阶段侦听器。反过来,“为什么”也不能建设性地回答。如果您对同一阶段监听器被注册两次感到困扰,只需删除第二次注册。

于 2013-08-28T13:08:50.573 回答
0

如果您使用的是 Tomcat 7.0.4x,则会出现此问题。尝试将 Tomcat 降级到至少 7.0.39 或更低版本。问题很可能会得到解决。我仍然不知道原因,但它有效。希望能帮助到你。

于 2013-12-30T19:25:53.430 回答