重写/带有参数的 PrettyFaces 导致 IllegalStateException:提交响应后无法创建会话

Rewrite / PrettyFaces with parameter causes IllegalStateException: Cannot create a session after the response has been committed

我想在我的 JSF 2.2 应用程序中使用一些带有注释的 url 重写器,所以我开始尝试使用 RewritePrettyFaces 后继者)。

我的应用程序仍然只是一个 hello world 运行 在 TomEE 7.x 中,我猜这里没有花哨的依赖项。我 运行 没有 web.xml,空 faces-config.xml 和空 beans.xml

我创建了一个新的专用支持 bean 和 xhtml 来测试 Rewrite,问题是每当我在 Url 中添加一个参数时,我得到一个 IllegalStateException提交响应后无法创建会话

我尝试降级到 PrettyFaces 3.3.3,但出现了完全相同的错误。

这是Backing Bean的代码

@Named
@javax.enterprise.context.RequestScoped
@URLMapping(id = "testroot", pattern = "/testRoot/#{testRootView.bar}", viewId = "xyz/TestRoot.jsf")
public class TestRootView implements Serializable {

    String foo = "my first String";

    String bar ="";

    // getters and setters ...
}

和视图

<?xml version="1.0" encoding="UTF-8"?>
<body jsf:id="root-body" xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://xmlns.jcp.org/jsf/html"
      xmlns:ui="http://xmlns.jcp.org/jsf/facelets"
      xmlns:f="http://xmlns.jcp.org/jsf/core"
      xmlns:jsf="http://xmlns.jcp.org/jsf">

<p>
This is my string : #{testRootView.foo}
</p>

<p>
And this is another string : #{testRootView.bar}
</p>

</body>

以及我访问 http://localhost:8080/testRoot/aaa

时的堆栈跟踪

java.lang.IllegalStateException: Cannot create a session after the response has been committed org.apache.catalina.connector.Request.doGetSession(Request.java:2952) org.apache.catalina.connector.Request.getSession(Request.java:2361) org.apache.catalina.connector.RequestFacade.getSession(RequestFacade.java:896) javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:231) javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:231) org.apache.myfaces.context.servlet.SessionMap.setAttribute(SessionMap.java:56) org.apache.myfaces.util.AbstractThreadSafeAttributeMap.put(AbstractThreadSafeAttributeMap.java:109) org.apache.myfaces.util.AbstractThreadSafeAttributeMap.put(AbstractThreadSafeAttributeMap.java:38) org.apache.myfaces.application.viewstate.ServerSideStateCacheImpl.saveSerializedViewInServletSession(ServerSideStateCacheImpl.java:250) org.apache.myfaces.application.viewstate.ServerSideStateCacheImpl.saveSerializedView(ServerSideStateCacheImpl.java:642) org.apache.myfaces.renderkit.html.HtmlResponseStateManager.saveState(HtmlResponseStateManager.java:138) org.apache.myfaces.application.StateManagerImpl.saveView(StateManagerImpl.java:279) org.apache.myfaces.shared.view.JspViewDeclarationLanguageBase.renderView(JspViewDeclarationLanguageBase.java:220) org.apache.myfaces.application.ViewHandlerImpl.renderView(ViewHandlerImpl.java:313) com.ocpsoft.pretty.faces.application.PrettyViewHandler.renderView(PrettyViewHandler.java:163) javax.faces.application.ViewHandlerWrapper.renderView(ViewHandlerWrapper.java:58) javax.faces.application.ViewHandlerWrapper.renderView(ViewHandlerWrapper.java:58) org.omnifaces.viewhandler.OmniViewHandler.renderView(OmniViewHandler.java:115) org.apache.myfaces.lifecycle.RenderResponseExecutor.execute(RenderResponseExecutor.java:116) org.apache.myfaces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:267) javax.faces.webapp.FacesServlet.service(FacesServlet.java:200) org.apache.tomee.myfaces.TomEEWorkaroundFacesServlet.service(TomEEWorkaroundFacesServlet.java:47) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) com.ocpsoft.pretty.PrettyFilter.doFilter(PrettyFilter.java:145) com.ocpsoft.pretty.PrettyFilter.doFilter(PrettyFilter.java:137)

请注意,如果我从模式 (pattern = "/testRoot") 中删除参数并访问 http://localhost:8080/testRoot 则没有问题并且视图呈现良好。

我做错了什么? (我已经给出了带有 prettyfaces 的版本,我也可以给出带有 Rewrite 的 @Join 的版本,但我认为问题出在其他地方,因为错误是相同的...)

感谢chkal,我找到了问题,确实是viewId字段(或to字段中缺少根('/') =12=]版本)。

添加它解决了这个问题。我仍然想知道我的代码将在哪里搜索会话,如果它找到一个会话会做什么:)