IllegalStateException:getAttribute:会话已经失效
Posted
技术标签:
【中文标题】IllegalStateException:getAttribute:会话已经失效【英文标题】:IllegalStateException: getAttribute: Session already invalidated 【发布时间】:2011-06-17 03:44:46 【问题描述】:我的第一个 JSF/IceFaces(版本 1.8.2)应用程序在 JBoss 5.1.0 上运行时遇到问题。
一段时间后我收到一个异常,告诉我会话问题。这很奇怪,因为我根本不在我的代码中使用会话。以下日志显示,由于此错误(来自 JBoss),我的所有支持 bean 都无法实例化:
com.sun.faces.mgbean.ManagedBeanCreationException:无法实例化类:bean.Abgrenzungsreise。 在 com.sun.faces.mgbean.BeanBuilder.newBeanInstance(BeanBuilder.java:191) 在 com.sun.faces.mgbean.BeanBuilder.build(BeanBuilder.java:106) 在 com.sun.faces.mgbean.BeanManager.createAndPush(BeanManager.java:368) 在 com.sun.faces.mgbean.BeanManager.create(BeanManager.java:222) 在 com.sun.faces.el.ManagedBeanELResolver.getValue(ManagedBeanELResolver.java:86) 在 javax.el.CompositeELResolver.getValue(CompositeELResolver.java:54) 在 com.sun.faces.el.FacesCompositeELResolver.getValue(FacesCompositeELResolver.java:72) 在 org.apache.el.parser.AstIdentifier.getValue(AstIdentifier.java:61) 在 org.apache.el.parser.AstValue.getValue(AstValue.java:107) 在 org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:186) 在 javax.faces.component.UISelectItems.getValue(UISelectItems.java:141) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.getSelectItems(MenuRenderer.java:637) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.countSelectOptionsRecursive(MenuRenderer.java:448) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.renderSelect(MenuRenderer.java:377) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.encodeEnd(MenuRenderer.java:119) 在 com.icesoft.faces.component.ext.renderkit.MenuRenderer.encodeEnd(MenuRenderer.java:51) 在 javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:861) 在 com.icesoft.faces.renderkit.dom_html_basic.DomBasicRenderer.encodeParentAndChildren(DomBasicRenderer.java:370) 在 com.icesoft.faces.renderkit.dom_html_basic.GridRenderer.encodeChildren(GridRenderer.java:208) 在 javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:837) 在 com.icesoft.faces.renderkit.dom_html_basic.DomBasicRenderer.encodeParentAndChildren(DomBasicRenderer.java:358) 在 com.icesoft.faces.renderkit.dom_html_basic.GroupRenderer.encodeChildren(GroupRenderer.java:96) 在 javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:837) 在 com.icesoft.faces.component.util.CustomComponentUtils.renderChild(CustomComponentUtils.java:339) 在 com.icesoft.faces.component.paneltabset.PanelTabSetRenderer.writeTabCell(PanelTabSetRenderer.java:977) 在 com.icesoft.faces.component.paneltabset.PanelTabSetRenderer.encodeEnd(PanelTabSetRenderer.java:423) 在 javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:861) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:503) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:456) 在 com.icesoft.faces.application.D2DViewHandler.renderView(D2DViewHandler.java:159) 在 com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:110) 在 com.sun.faces.lifecycle.Phase.doPhase(Phase.java:100) 在 com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139) 在 com.icesoft.faces.webapp.http.core.JsfLifecycleExecutor.apply(JsfLifecycleExecutor.java:19) 在 com.icesoft.faces.context.View$2$1.respond(View.java:48) 在 com.icesoft.faces.webapp.http.servlet.ServletRequestResponse.respondWith(ServletRequestResponse.java:201) 在 com.icesoft.faces.context.View$2.serve(View.java:77) 在 com.icesoft.faces.context.View.servePage(View.java:149) 在 com.icesoft.faces.webapp.http.core.SingleViewServer.service(SingleViewServer.java:52) 在 com.icesoft.faces.webapp.http.common.ServerProxy.service(ServerProxy.java:11) 在 com.icesoft.faces.webapp.http.servlet.MainSessionBoundServlet$4.service(MainSessionBoundServlet.java:149) 在 com.icesoft.faces.webapp.http.common.standard.PathDispatcherServer.service(PathDispatcherServer.java:24) 在 com.icesoft.faces.webapp.http.servlet.BasicAdaptingServlet.service(BasicAdaptingServlet.java:16) 在 com.icesoft.faces.webapp.http.servlet.PathDispatcher.service(PathDispatcher.java:23) 在 com.icesoft.faces.webapp.http.servlet.SessionDispatcher.service(SessionDispatcher.java:53) 在 com.icesoft.faces.webapp.http.servlet.PathDispatcher.service(PathDispatcher.java:23) 在 com.icesoft.faces.webapp.http.servlet.MainServlet.service(MainServlet.java:131) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 在 org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:638) 在 org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:444) 在 org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:382) 在 org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:310) 在 org.apache.jasper.runtime.PageContextImpl.doForward(PageContextImpl.java:696) 在 org.apache.jasper.runtime.PageContextImpl.forward(PageContextImpl.java:667) 在 org.apache.jsp.index_jsp._jspService(index_jsp.java:58) 在 org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 在 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:369) 在 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:322) 在 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:249) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 在 org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 在 org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:235) 在 org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) 在 org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:190) 在 org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:92) 在 org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.process(SecurityContextEstablishmentValve.java:126) 在 org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.invoke(SecurityContextEstablishmentValve.java:70) 在 org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) 在 org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 在 org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:158) 在 org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) 在 org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:330) 在 org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:829) 在 org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:598) 在 org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447) 在 java.lang.Thread.run(Thread.java:662) 原因:com.icesoft.faces.webapp.http.core.SessionExpiredException:用户会话已过期或无效。 在 com.icesoft.faces.webapp.http.servlet.ProxyHttpSession.getAttribute(ProxyHttpSession.java:77) 在 com.icesoft.faces.webapp.http.servlet.ServletSessionAttributeMap.getAttribute(ServletSessionAttributeMap.java:16) 在 com.icesoft.faces.context.AbstractAttributeMap.containsKey(AbstractAttributeMap.java:85) 在 com.sun.faces.mgbean.BeanManager.isBeanInScope(BeanManager.java:177) 在 com.sun.faces.el.ManagedBeanELResolver.getValue(ManagedBeanELResolver.java:82) 在 javax.el.CompositeELResolver.getValue(CompositeELResolver.java:54) 在 com.sun.faces.el.FacesCompositeELResolver.getValue(FacesCompositeELResolver.java:72) 在 bean.Abgrenzungsreise.(Abgrenzungsreise.java:39) 在 sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 在 sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 在 sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 在 java.lang.reflect.Constructor.newInstance(Constructor.java:513) 在 java.lang.Class.newInstance0(Class.java:355) 在 java.lang.Class.newInstance(Class.java:308) 在 com.sun.faces.mgbean.BeanBuilder.newBeanInstance(BeanBuilder.java:186) ... 86 更多 引起:java.lang. 在 org.apache.catalina.session.StandardSession.getAttribute(StandardSession.java:1032) 在 org.apache.catalina.session.StandardSessionFacade.getAttribute(StandardSessionFacade.java:110) 在 com.icesoft.faces.webapp.http.servlet.ProxyHttpSession.getAttribute(ProxyHttpSession.java:75) ... 100 多个 2011-01-28 08:05:54,326 错误 [com.icesoft.faces.context.View] (http-0.0.0.0-8080-3) View.servePage 期间遇到的问题 com.sun.faces.mgbean.ManagedBeanCreationException:无法实例化类:bean.Abgrenzungsreise。 在 com.sun.faces.mgbean.BeanBuilder.newBeanInstance(BeanBuilder.java:191) 在 com.sun.faces.mgbean.BeanBuilder.build(BeanBuilder.java:106) 在 com.sun.faces.mgbean.BeanManager.createAndPush(BeanManager.java:368) 在 com.sun.faces.mgbean.BeanManager.create(BeanManager.java:222) 在 com.sun.faces.el.ManagedBeanELResolver.getValue(ManagedBeanELResolver.java:86) 在 javax.el.CompositeELResolver.getValue(CompositeELResolver.java:54) 在 com.sun.faces.el.FacesCompositeELResolver.getValue(FacesCompositeELResolver.java:72) 在 org.apache.el.parser.AstIdentifier.getValue(AstIdentifier.java:61) 在 org.apache.el.parser.AstValue.getValue(AstValue.java:107) 在 org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:186) 在 javax.faces.component.UISelectItems.getValue(UISelectItems.java:141) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.getSelectItems(MenuRenderer.java:637) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.countSelectOptionsRecursive(MenuRenderer.java:448) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.renderSelect(MenuRenderer.java:377) 在 com.icesoft.faces.renderkit.dom_html_basic.MenuRenderer.encodeEnd(MenuRenderer.java:119) 在 com.icesoft.faces.component.ext.renderkit.MenuRenderer.encodeEnd(MenuRenderer.java:51) 在 javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:861) 在 com.icesoft.faces.renderkit.dom_html_basic.DomBasicRenderer.encodeParentAndChildren(DomBasicRenderer.java:370) 在 com.icesoft.faces.renderkit.dom_html_basic.GridRenderer.encodeChildren(GridRenderer.java:208) 在 javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:837) 在 com.icesoft.faces.renderkit.dom_html_basic.DomBasicRenderer.encodeParentAndChildren(DomBasicRenderer.java:358) 在 com.icesoft.faces.renderkit.dom_html_basic.GroupRenderer.encodeChildren(GroupRenderer.java:96) 在 javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:837) 在 com.icesoft.faces.component.util.CustomComponentUtils.renderChild(CustomComponentUtils.java:339) 在 com.icesoft.faces.component.paneltabset.PanelTabSetRenderer.writeTabCell(PanelTabSetRenderer.java:977) 在 com.icesoft.faces.component.paneltabset.PanelTabSetRenderer.encodeEnd(PanelTabSetRenderer.java:423) 在 javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:861) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:503) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:497) 在 com.icesoft.faces.application.D2DViewHandler.renderResponse(D2DViewHandler.java:456) 在 com.icesoft.faces.application.D2DViewHandler.renderView(D2DViewHandler.java:159) 在 com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:110) 在 com.sun.faces.lifecycle.Phase.doPhase(Phase.java:100) 在 com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139) 在 com.icesoft.faces.webapp.http.core.JsfLifecycleExecutor.apply(JsfLifecycleExecutor.java:19) 在 com.icesoft.faces.context.View$2$1.respond(View.java:48) 在 com.icesoft.faces.webapp.http.servlet.ServletRequestResponse.respondWith(ServletRequestResponse.java:201) 在 com.icesoft.faces.context.View$2.serve(View.java:77) 在 com.icesoft.faces.context.View.servePage(View.java:149) 在 com.icesoft.faces.webapp.http.core.SingleViewServer.service(SingleViewServer.java:52) 在 com.icesoft.faces.webapp.http.common.ServerProxy.service(ServerProxy.java:11) 在 com.icesoft.faces.webapp.http.servlet.MainSessionBoundServlet$4.service(MainSessionBoundServlet.java:149) 在 com.icesoft.faces.webapp.http.common.standard.PathDispatcherServer.service(PathDispatcherServer.java:24) 在 com.icesoft.faces.webapp.http.servlet.BasicAdaptingServlet.service(BasicAdaptingServlet.java:16) 在 com.icesoft.faces.webapp.http.servlet.PathDispatcher.service(PathDispatcher.java:23) 在 com.icesoft.faces.webapp.http.servlet.SessionDispatcher.service(SessionDispatcher.java:53) 在 com.icesoft.faces.webapp.http.servlet.PathDispatcher.service(PathDispatcher.java:23) 在 com.icesoft.faces.webapp.http.servlet.MainServlet.service(MainServlet.java:131) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 在 org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:638) 在 org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:444) 在 org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:382) 在 org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:310) 在 org.apache.jasper.runtime.PageContextImpl.doForward(PageContextImpl.java:696) 在 org.apache.jasper.runtime.PageContextImpl.forward(PageContextImpl.java:667) 在 org.apache.jsp.index_jsp._jspService(index_jsp.java:58) 在 org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 在 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:369) 在 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:322) 在 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:249) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 在 org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 在 org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:235) 在 org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) 在 org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:190) 在 org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:92) 在 org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.process(SecurityContextEstablishmentValve.java:126) 在 org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.invoke(SecurityContextEstablishmentValve.java:70) 在 org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) 在 org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 在 org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:158) 在 org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) 在 org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:330) 在 org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:829) 在 org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:598) 在 org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447) 在 java.lang.Thread.run(Thread.java:662) 原因:com.icesoft.faces.webapp.http.core.SessionExpiredException:用户会话已过期或无效。 在 com.icesoft.faces.webapp.http.servlet.ProxyHttpSession.getAttribute(ProxyHttpSession.java:77) 在 com.icesoft.faces.webapp.http.servlet.ServletSessionAttributeMap.getAttribute(ServletSessionAttributeMap.java:16) 在 com.icesoft.faces.context.AbstractAttributeMap.containsKey(AbstractAttributeMap.java:85) 在 com.sun.faces.mgbean.BeanManager.isBeanInScope(BeanManager.java:177) 在 com.sun.faces.el.ManagedBeanELResolver.getValue(ManagedBeanELResolver.java:82) 在 javax.el.CompositeELResolver.getValue(CompositeELResolver.java:54) 在 com.sun.faces.el.FacesCompositeELResolver.getValue(FacesCompositeELResolver.java:72) 在 bean.Abgrenzungsreise.(Abgrenzungsreise.java:39) 在 sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 在 sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 在 sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 在 java.lang.reflect.Constructor.newInstance(Constructor.java:513) 在 java.lang.Class.newInstance0(Class.java:355) 在 java.lang.Class.newInstance(Class.java:308) 在 com.sun.faces.mgbean.BeanBuilder.newBeanInstance(BeanBuilder.java:186) ... 86 更多 引起:java.lang. 在 org.apache.catalina.session.StandardSession.getAttribute(StandardSession.java:1032) 在 org.apache.catalina.session.StandardSessionFacade.getAttribute(StandardSessionFacade.java:110) 在 com.icesoft.faces.webapp.http.servlet.ProxyHttpSession.getAttribute(ProxyHttpSession.java:75) ... 100 多个我发现异常是在最后一次用户活动后半小时引发的。
【问题讨论】:
我发现该错误发生在用户最后一次操作后 30 分钟。 【参考方案1】:IceFaces 论坛上报告了同样的问题:
http://www.icefaces.org/JForum/posts/list/7752.page http://www.icefaces.org/JForum/posts/list/18154.page建议的解决方案是:
一旦我们关闭异步模式,就会发生这种情况
<!-- Specifies to the ICEfaces framework that synchronous update mode is to be used. By default, ICEfaces uses asynchronous update mode to support server-initiated updates (AJAX push). Setting to true will enable synchronous update mode and disable AJAX push features. --> <context-param> <param-name>com.icesoft.faces.synchronousUpdate</param-name> <param-value>true</param-value> </context-param>
如果这是错误的,我们会收到漂亮的小会话超时消息。 如果这是真的,会话超时行为就是堆栈跟踪。
和
与此同时,我已经从 ICEfaces 1.8.2 切换到 svn 存储库中的内容(1.8.3+)。而且行为发生了变化。没有崩溃了。
关于您没有在任何地方使用会话的声明,堆栈跟踪告诉它在抛出此异常时正在尝试创建会话范围的托管 bean。所以你肯定在使用会话:)
更新 根据 cmets:您确实不应该将(基于请求的!!)FacesContext
分配为 static
变量。此外,需要由<managed-property>
在faces-config.xml
中注入其他bean。否则它根本不是“注入”,而只是 手动 访问另一个 bean。通过注入,您可以让 JSF 将另一个 bean 设置为当前 bean 的属性。一个例子可以在here找到。
【讨论】:
@BalusC:OP 可能不打算使用会话,但我认为他使用了一些需要它们的东西。 @elusive:堆栈跟踪告诉他有一个<f:selectItems>
,它绑定到一个会话范围的托管bean。绝对是他自己在视图中声明的。可能他没有意识到“会话范围”的含义,他实际上的意思是他没有在自己的代码中手动调用 request.getSession()
或任何东西。
首先,感谢您的回答。默认情况下,这是按照您的建议配置的。所以这似乎不是错误的原因。
所以已经是false
了?升级到 1.8.3 或更高版本没有帮助?
我知道幕后有一些会话的事情。我想在我的问题中说的是我没有明确使用它们。这个错误可能是由private static FacesContext facesContext = FacesContext.getCurrentInstance(); private utils.Error errorBean;
和 bean 的构造函数 errorBean = (utils.Error) facesContext.getApplication().getELResolver().getValue(facesContext.getELContext(), null, "error");
将一个会话 bean 注入另一个会话 bean 引起的吗?【参考方案2】:
异常的原因是在我的 SessionBean 类中。 我在上面问过原因是否可能是通过 facesContext 将 bean 注入另一个。 现在我自己给出答案:“是的,这可能是原因。”
public class MySessionBean
private static FacesContext facesContext = FacesContext.getCurrentInstance();
private utils.AnotherSessionBean injectedSessionBean = (utils.AnotherSessionBean) facesContext.getApplication().getELResolver().getValue(facesContext.getELContext(), null, "anotherSessionBean");
// ...
我可以随意在任何方法或构造函数之外实例化当前的 FacesContext,这不是一个好主意,因为在会话超时之后,我使用了旧的或者可能没有会话上下文。 MySessionBean 已重新加载或获取它的新实例,但它没有刷新 FacesContext。上面描述了这个结果^^
结论:所以获取 FacesContext 属于方法或构造函数的代码块。
非常感谢您的帮助!
【讨论】:
以上是关于IllegalStateException:getAttribute:会话已经失效的主要内容,如果未能解决你的问题,请参考以下文章
IllegalStateException: Failed to get nested archive for entry BOOT-INF/lib/mybatis-plus-support-jar
java.lang.IllegalStateException: Cannot get a STRING value from a NUMERIC cell
异常Caused by: java.lang.IllegalStateException: Method has too many Body parameters
设置 mMediaRecorder.setProfile 时出现 IllegalStateException