Ошибка java.lang.NullPointerException - PullRequest
       0

Ошибка java.lang.NullPointerException

0 голосов
/ 23 августа 2011

Я использую JSF / primefaces У меня ошибка, которая странная, потому что я вызываю тот же метод из другой формы и работает нормально, но из этой формы выдает ошибку!

<h:form id="f7">
   <p:panel visible="#{TestAjax.form7Visible}" style="width: 800px;">
      <h:panelGrid id="panForm7" columns="1">
         <h:selectManyListbox   value="#{TestAjax.selectedProjects}"  id="project7" size="3">
           <f:selectItem itemLabel="-- Select Projects -- " itemValue="0"/> 
           <f:selectItems value="#{TestAjax.getMyListProject()}" />
         </h:selectManyListbox>

         <h:selectOneMenu id="chartTypeCh" value="#{TestAjax.chartType}">
           <f:selectItem itemValue="PieChart" itemLabel="PieChart"/>
           <f:selectItem itemValue="BarChart" itemLabel="BarChart"/>
           <f:selectItem itemValue="Table" itemLabel="Table"/>
         </h:selectOneMenu> 

         FROM:<p:calendar  value="#{TestAjax.date1}" showOn="button" />  
         TO :<p:calendar  value="#{TestAjax.date2}" showOn="button" /> 
      <p:commandButton ajax="false" action="#{TestAjax.fillReport2()}" value="OK"></p:commandButton>
  </h:panelGrid>
 </p:panel>
</h:form>

ошибка:

ATTENTION: #{TestAjax.fillReport2()}: java.lang.NullPointerException
javax.faces.FacesException: #{TestAjax.fillReport2()}: java.lang.NullPointerException
at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:118)
at javax.faces.component.UICommand.broadcast(UICommand.java:315)
at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:794)
at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1259)
at 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)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:409)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1534)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:281)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595)
at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:98)
at  com.sun.enterprise.web.PESessionLockingStandardPipeline.invoke(PESessionLockingStandardPipeline.java:91)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:162)
at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:326)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:227)
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:170)
at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:822)
at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:719)
at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1013)
at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:225)
at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137)
at 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)
at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59)
at 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)
at java.lang.Thread.run(Thread.java:662)
Caused by: javax.faces.el.EvaluationException: java.lang.NullPointerException
at  javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:102)
at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:102)
... 32 more
Caused by: java.lang.NullPointerException
at DAOKPI.TestAjax.createQueryOracle2(TestAjax.java:1201)
at DAOKPI.TestAjax.fillReport2(TestAjax.java:925)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at javax.el.BeanELResolver.invokeMethod(BeanELResolver.java:737)
at javax.el.BeanELResolver.invoke(BeanELResolver.java:467)
at javax.el.CompositeELResolver.invoke(CompositeELResolver.java:254)
at com.sun.el.parser.AstValue.invoke(AstValue.java:228)
at com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:297)
at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105)
at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:88)
... 33 more

1 Ответ

3 голосов
/ 23 августа 2011

Посмотрите на самую нижнюю причину трассировки стека:

Caused by: java.lang.NullPointerException
at DAOKPI.TestAjax.createQueryOracle2(TestAjax.java:1201)

Откройте DAOKPI.TestAjax класс и перейдите к createQueryOracle2() методу. Строка 1201 должна выглядеть примерно так:

someObject.doSomething();

Это исключение пытается сообщить вам, что someObject - это null. Вам нужно исправить это, убедившись, что это , а не null в точке, где вы это называете. Например, просто создав его экземпляр.

if (someObject == null) {
    someObject = new SomeObject();
}
someObject.doSomething();

Вы также можете просто пропустить вызов, предварительно проверив, не является ли он null.

if (someObject != null) {
    someObject = new SomeObject();
}

Или, если оно представляет собой свойство управляемого компонента или какое-либо свойство внедрения зависимости, убедитесь, что области действия правильные и что инжектор выполнил свою работу.


Не связанный с конкретной проблемой, класс управляемых бинов с более чем 1201 строкой - это действительно дизайнерский запах. Рассмотрим рефакторинг. Например, поля формы могут входить в класс сущности / javabean. Бизнес-задачи могут идти в сервисном классе. Задачи взаимодействия с базой данных могут идти в классе DAO. Все, что может быть свойствами управляемого компонента.

Имена пакетов в верхнем регистре также не соответствуют соглашениям об именах Java . Кроме того, прямые выражения метода EL, такие как #{TestAjax.getMyListProject()} и #{TestAjax.fillReport2()} безобразны, если вам не нужно передавать аргументы или вызывать не получателей, лучше используйте #{TestAjax.myListProject} и #{TestAjax.fillReport2}. Наконец, имена управляемых JSF-компонентов должны начинаться со строчной буквы, поскольку они представляют собой только экземпляры класса: #{testAjax}.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...