最近学习JSF遇到一个异常:
页面代码很简单:
因为导致异常的原因是添加了这个
h:commandButton,最后才发现是因为它写在了h:form外导致的,改到里面就没有问题了,郁闷的是页面上其实已经告诉我了。。。
- 2008-11-7 16:51:26 javax.faces.webapp._ErrorPageWriter handleException
- 严重: An exception occurred
- javax.faces.FacesException: Exception while calling encodeEnd on component : {Component-Path : [Class: javax.faces.component.UIViewRoot,ViewId: /tag.jsp][Class: javax.faces.component.html.HtmlPanelGrid,Id: j_id_jsp_1428050167_1]}
- at javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:559)
- at javax.faces.component.UIComponent.encodeAll(UIComponent.java:250)
- at javax.faces.component.UIComponent.encodeAll(UIComponent.java:246)
- at org.apache.myfaces.application.jsp.JspViewHandlerImpl.actuallyRenderView(JspViewHandlerImpl.java:423)
- at org.apache.myfaces.application.jsp.JspViewHandlerImpl.renderView(JspViewHandlerImpl.java:380)
- at org.apache.myfaces.lifecycle.RenderResponseExecutor.execute(RenderResponseExecutor.java:41)
- at org.apache.myfaces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:140)
- at javax.faces.webapp.FacesServlet.service(FacesServlet.java:152)
- at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
- at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
- at org.apache.myfaces.webapp.filter.ExtensionsFilter.doFilter(ExtensionsFilter.java:147)
- at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
- at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
- at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:228)
- at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
- at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
- at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
- at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
- at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:216)
- at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
- at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:634)
- at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:445)
- at java.lang.Thread.run(Unknown Source)
- Caused by: javax.faces.FacesException: Exception while calling encodeEnd on component : {Component-Path : [Class: javax.faces.component.UIViewRoot,ViewId: /tag.jsp][Class: javax.faces.component.html.HtmlPanelGrid,Id: j_id_jsp_1428050167_1][Class: javax.faces.component.html.HtmlCommandButton,Id: check]}
- at javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:559)
- at org.apache.myfaces.shared_impl.renderkit.RendererUtils.renderChild(RendererUtils.java:515)
- at org.apache.myfaces.shared_impl.renderkit.html.HtmlGridRendererBase.renderChildren(HtmlGridRendererBase.java:221)
- at org.apache.myfaces.shared_impl.renderkit.html.HtmlGridRendererBase.encodeEnd(HtmlGridRendererBase.java:102)
- at javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:556)
- ... 22 more
- Caused by: java.lang.IllegalArgumentException: Component check must be embedded in an form
- at org.apache.myfaces.shared_impl.renderkit.html.HtmlButtonRendererBase.buildOnClick(HtmlButtonRendererBase.java:181)
- at org.apache.myfaces.shared_impl.renderkit.html.HtmlButtonRendererBase.encodeEnd(HtmlButtonRendererBase.java:120)
- at javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:556)
- ... 26 more
- </h:form>
- <h:commandButton id="check" value="#{msgs.checkText}" actionListener="#{user.check}"></h:commandButton>
- An Error Occurred:
- Exception while calling encodeEnd on component : {Component-Path : [Class: javax.faces.component.UIViewRoot,ViewId: /tag.jsp][Class: javax.faces.component.html.HtmlCommandButton,Id: check]}
- Caused by:
- java.lang.IllegalArgumentException - Component check must be embedded in an form