@Eager недоступен. Не удалось получить репозиторий EagerBeans от диспетчера компонентов CDI

Это мое первое использование омнифасов. Мое приложение работает хорошо без него, но когда я попробовал его, я получил следующее исключение.

java.lang.NullPointerException
    at org.omnifaces.cdi.eager.EagerBeansPhaseListener.afterPhase(EagerBeansPhaseListener.java:50)
    at com.sun.faces.lifecycle.Phase.handleAfterPhase(Phase.java:189)
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:107)
    at com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:123)
    at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:658)
    at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1550)
    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 org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:161)
    at 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)
    at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:195)
    at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:860)
    at com.sun.grizzly.arp.DefaultAsyncExecutor.execute(DefaultAsyncExecutor.java:159)
    at com.sun.grizzly.arp.DefaultAsyncExecutor.interrupt(DefaultAsyncExecutor.java:145)
    at com.sun.grizzly.arp.AsyncProcessorTask.doTask(AsyncProcessorTask.java:102)
    at com.sun.grizzly.http.TaskBase.run(TaskBase.java:193)
    at com.sun.grizzly.http.TaskBase.execute(TaskBase.java:175)
    at com.sun.grizzly.arp.DefaultAsyncHandler.handle(DefaultAsyncHandler.java:145)
    at com.sun.grizzly.arp.AsyncProtocolFilter.execute(AsyncProtocolFilter.java:210)
    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:745)

Я создал новое пустое веб-приложение в Netbeans, запустил его под Glassfish 3.1.2.2, используя: OmniFaces версия 2.1 Mojarra 2.2.12 PrimeFaces 5.3 PrimeFaces Extensions 3.2. и все равно получаю ту же ошибку каждый раз, когда я запускаю приложение со следующим предупреждением при запуске стеклянной рыбы:

@Eager недоступен. Не удалось получить репозиторий EagerBeans из диспетчера компонентов CDI.

Любая помощь, пожалуйста?

Когда я удаляю omnifaces-2.1.jar из каталога glassfish domain1/lib, все работает нормально.

1 ответ

Решение

Когда я удаляю omnifaces-2.1.jar из каталога glassfish domain1/lib, все работает нормально.

Веб-библиотеки там не принадлежат. Веб-библиотеки принадлежат /WEB-INF/lib ВОЙНЫ. Когда неуместно снаружи /WEB-INF/libтогда веб-приложение не сможет найти аннотированные классы JSF/CDI в веб-библиотеке и выбросить исключения, связанные с этим.

Верните обратно файл JAR OmniFaces из domain1/lib в /WEB-INF/lib, Тогда JSF сможет найти @FacesComponent аннотированные классы, включенные в OmniFaces и CDI, смогут найти @XxxScoped классы, связанные в OmniFaces, такие как EagerBeansRepository учебный класс.

Смотрите также раздел "Установка" домашней страницы OmniFaces:

Монтаж

Это вопрос удаления файла JAR OmniFaces 2.1 в /WEB-INF/lib,

...

OmniFaces спроектирован как библиотека WAR (библиотека веб-фрагментов) и поэтому не может быть размещен где-либо еще в пути к классам во время выполнения веб-приложения вне собственного WAR /WEB-INF/libтакие как EAR's /lib или даже собственный сервер или JRE /lib, Когда JAR-файл OmniFaces таким образом перемещается, веб-приложение не сможет найти аннотированные классы JSF/CDI в комплекте с OmniFaces и выбросить связанные с этим исключения во время развертывания или выполнения. Чтобы решить эту проблему, верните OmniFaces в WAR /WEB-INF/lib,

Другие вопросы по тегам