Исключение при загрузке веб-страницы Primefaces

Когда я пытаюсь загрузить свою веб-страницу, я получаю следующее исключение: java.lang.NoSuchMethodError: org.primefaces.context.DefaultRequestContext.(Ljavax/faces/context/FacesContext;)V

Я пытался выяснить, откуда оно берется, но ничего не смог выяснить :( Вы когда-нибудь сталкивались с этим исключением и знаете, как его решить?

Вот полная трассировка стека от Glassfish:

WARNUNG: StandardWrapperValve[Faces Servlet]: PWC1406: Servlet.service() for servlet Faces Servlet threw exception
java.lang.NoSuchMethodError: org.primefaces.context.DefaultRequestContext.<init>(Ljavax/faces/context/FacesContext;)V
at org.primefaces.context.PrimeFacesContext.<init>(PrimeFacesContext.java:16)
at org.primefaces.context.PrimeFacesContextFactory.getFacesContext(PrimeFacesContextFactory.java:23)
at com.sun.faces.context.InjectionFacesContextFactory.getFacesContext(InjectionFacesContextFactory.java:121)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:583)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1542)
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:849)
at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:746)
at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1045)
at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:228)
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)[/code]

Заранее спасибо Сера


person xeraphim    schedule 21.05.2013    source источник
comment
Используете ли вы Morjarra или Myfaces и включили ли вы jar-файл Primefaces в свой проект?   -  person Rong Nguyen    schedule 21.05.2013
comment
У вас может быть несколько JAR-файлов PrimeFaces с разными версиями в пути к классам времени выполнения вашего веб-приложения.   -  person Rong Nguyen    schedule 21.05.2013
comment
спасибо, RongNK, на самом деле это была проблема :-) у нас было две разные версии простых лиц в нашем пути к классам. Благодарность :)   -  person xeraphim    schedule 31.05.2013
comment
Добро пожаловать, вы должны опубликовать как ответ, чтобы закрыть свой вопрос!   -  person Rong Nguyen    schedule 31.05.2013


Ответы (2)


Как правильно предположил RongNK, у нас было несколько версий PrimeFaces в нашем пути к классам, которые вызывают эту ошибку. Еще раз спасибо РонгНК :)

person xeraphim    schedule 31.05.2013

я получил аналогичную ошибку от @ManagedBean

java.lang.NoSuchMethodError: пакет.ManagedBean.

Но ManagedBean предоставляет метод public init() {...}

вот что у меня сработало: просто реализуйте публичный конструктор без параметров для класса ошибок.

person jkl    schedule 08.07.2015