私はしばらくこれに取り組んできましたが、このコンポーネントを次のように完全に機能させることができました。
<h:form enctype="multipart/form-data">
<p:panelGrid columns="2">
<p:outputLabel value="Nombre:" for="nombre"/>
<p:inputText id="nombre" value="# {controladorProducto.producto.nombre}"/>
<p:outputLabel value="Descripción" for="descripcion"/>
<p:inputText id="descripcion" value="#{controladorProducto.producto.descripcion}"/>
<p:outputLabel value="Precio" for="precio"/>
<p:inputText id="precio" value="#{controladorProducto.producto.precio}"/>
<p:fileUpload id="fileuploader" value="#{controladorProducto.uploadedFile}"
mode="simple" />
<p:commandButton id="boton_cargar" value="Cargar" actionListener="#{controladorProducto.handleProductImageUpload}"
update="fotoProducto" ajax="true"/>
<p:outputLabel value="Imagen:" for="fotoProducto"/>
<p:graphicImage id="fotoProducto" value="#{controladorProducto.producto.imageToShow}"/>
<p:commandButton value="Insertar" action="#{controladorProducto.insertarProducto()}"/>
</p:panelGrid>
</h:form>
そのため、UI コンポーネント (テンプレートなど) を追加するとすぐに機能しなくなります。テンプレートコードを含むフォームは次のとおりです。
<ui:define name="top">
<h1>Buscador Clientes</h1>
<h:form id="form_growl">
<p:growl showDetail="false" />
</h:form>
</ui:define>
<ui:define name="left">
<h:form>
<p:menubar>
<p:menuitem value="Clientes" action="#{controladorCliente.buscarTodosClientes}" />
<p:separator/>
<p:menuitem value="Productos" action="#{controladorProducto.buscarTodosProductos}"/>
<p:separator/>
<p:menuitem value="Pedidos" url="#"/>
</p:menubar>
</h:form>
</ui:define>
<ui:define name ="content">
<h:form enctype="multipart/form-data">
<p:panelGrid columns="2">
<p:outputLabel value="Nombre:" for="nombre"/>
<p:inputText id="nombre" value="#{controladorProducto.producto.nombre}"/>
<p:outputLabel value="Descripción" for="descripcion"/>
<p:inputText id="descripcion" value="#{controladorProducto.producto.descripcion}"/>
<p:outputLabel value="Precio" for="precio"/>
<p:inputText id="precio" value="#{controladorProducto.producto.precio}"/>
<p:fileUpload id="fileuploader" value="#{controladorProducto.uploadedFile}"
mode="simple" />
<p:commandButton id="boton_cargar" value="Cargar" actionListener="#{controladorProducto.handleProductImageUpload}"
update="fotoProducto" ajax="true"/>
<p:outputLabel value="Imagen:" for="fotoProducto"/>
<p:graphicImage id="fotoProducto" value="#{controladorProducto.producto.imageToShow}"/>
<p:commandButton value="Insertar" action="#{controladorProducto.insertarProducto()}"/>
</p:panelGrid>
</h:form>
</ui:define>
</ui:composition>
プロジェクトの他の場所で同じテンプレートを使用しましたが、問題なく動作しましたが、ここでクラッシュします。NullPointerException が発生し、それをデバッグすると、Bean も呼び出されませんでした。この時点で、私はインターネットを見回してきましたが、何も見つかりませんでした。なぜそれが機能しないのか、誰にもわかりませんか?
ちなみに、私は NetBeans 7.3、GlassFish 3.1.2、Primefaces 3.5、JSF 2.1 を使用しています....
誰かが私に答えてくれることを願っています。これに関する助けや手がかりをいただければ幸いです。
これは私が得るエラートレースです:
SEVERE: Se ha recibido 'java.lang.NullPointerException' al invocar la escucha de acción '#{controladorProducto.handleProductImageUpload}' para el componente 'boton_cargar' SEVERE: java.lang.NullPointerException at Controlador.ControladorProducto.handleProductImageUpload(ControladorProducto.java: 59) sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) で sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) で sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) で java.lang.reflect com.sun.el.parser.AstValue.invoke(AstValue.java:254) の .Method.invoke(Method.java:601) faces.event.MethodExpressionActionListener.processAction(MethodExpressionActionListener.java:153) で javax.faces.event.ActionEvent.processListener(ActionEvent.java:88) で javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:769) で javax.faces.component.UICommand .broadcast(UICommand.java:300) で javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:794) で javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1259) で com.sun.faces. lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81) at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101) at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118) javax.faces.webapp.FacesServlet.service(FacesServlet.java:593) で org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1550) で org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:343) org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:217) org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:79) org .apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256) org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:217) org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve) .java:279) org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655) org.apache.catalina. org.apache.catalina.core.StandardHostValve の core.StandardPipeline.invoke(StandardPipeline.java:595)。org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:331) の invoke(StandardHostValve.java:161) com.sun の org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:231) で.enterprise.v3.services.impl.ContainerMapper$AdapterCallable.call(ContainerMapper.java:317) com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:195) com.sun.grizzly .http.ProcessorTask.invokeAdapter(ProcessorTask.java:860) com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:757) com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1056) ) com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:229) で com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137) で com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104) at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90) at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79) at com.sun .grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54) com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59) com.sun.grizzly.ContextTask.run(ContextTask.java:71) com. java.lang.Thread.run(Thread.run(Thread.ジャワ:722)com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54) で execute(HttpProtocolChain.java:79) com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59) で com.sun.grizzly.ContextTask .run(ContextTask.java:71) at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532) at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) ) java.lang.Thread.run(Thread.java:722) でcom.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54) で execute(HttpProtocolChain.java:79) com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59) で com.sun.grizzly.ContextTask .run(ContextTask.java:71) at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532) at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) ) java.lang.Thread.run(Thread.java:722) でgrizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) at java.lang.Thread.run(Thread.java:722)grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) at java.lang.Thread.run(Thread.java:722)
SEVERE: JSF1073: SE HA Interceptado javax.faces.event.AbortProcessingException durante el procesamiento de INVOKE_APPLICATION 5: UIComponent-ClientId=j_idt22:boton_cargar, Mensaje=java.lang.NullPointerException SEVERE: java.lang.NullPointerException javax.faces.event.AbortProcessingException : javax.faces.event.MethodExpressionActionListener.processAction(MethodExpressionActionListener.java:182) での java.lang.NullPointerException (UIComponentBase.java:769) で javax.faces.component.UICommand.broadcast(UICommand.java:300) で javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:794) で javax.faces.component.UIViewRoot で。 com.sun.faces.lifecycle の processApplication(UIViewRoot.java:1259)。com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101) の InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81) com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118) の javax .faces.webapp.FacesServlet.service(FacesServlet.java:593) org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1550) org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java) :343) org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:217) で org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:79) で org.apache.catalina.core. org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:217) の ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256)。org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) で org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline. java:655) org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595) で org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:161) で org.apache.catalina.connector .CoyoteAdapter.doService(CoyoteAdapter.java:331) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:231) at com.sun.enterprise.v3.services.impl.ContainerMapper$AdapterCallable.call(ContainerMapper) .java:317) の com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:195) の com.sun.grizzly.http.ProcessorTask.com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:757) の invokeAdapter(ProcessorTask.java:860) com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1056) com.sun の.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:229) at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137) at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104) com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90) com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79) com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java: 54) com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59) で com.sun.grizzly.ContextTask.run(ContextTask.java:71) com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532) で com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) で java.lang.Thread .run(Thread.java:722) 原因: java.lang.NullPointerException at Controlador.ControladorProducto.handleProductImageUpload(ControladorProducto.java:59) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:57) の sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) の java.lang.reflect.Method.invoke(Method.java:601) の com.sun.el.parser.AstValue。 javax.faces.event.MethodExpressionActionListener で com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:302) で呼び出し (AstValue.java:254)。processAction(MethodExpressionActionListener.java:153) ... 38 もっと見る