java.lang.ClassNotFoundException: com.sun.faces.config.ConfigureListener при использовании MyFaces с WASCE/Geronimo
Я пытаюсь создать простое веб-приложение JSF, используя MyFaces v 2.1 с WebSphere Application Server Community Edition v3.0.0.1 и Eclipse Juno, но при попытке запустить приложение возвращается следующая ошибка
java.lang.ClassNotFoundException: com.sun.faces.config.ConfigureListener
org.apache.geronimo.common.DeploymentException: java.lang.ClassNotFoundException: com.sun.faces.config.ConfigureListener
at org.apache.geronimo.web25.deployment.AbstractWebModuleBuilder.createWebAppClassFinder(AbstractWebModuleBuilder.java:665)
at org.apache.geronimo.web25.deployment.AbstractWebModuleBuilder.configureBasicWebModuleAttributes(AbstractWebModuleBuilder.java:698)
at org.apache.geronimo.tomcat.deployment.TomcatModuleBuilder.addGBeans(TomcatModuleBuilder.java:469)
at org.apache.geronimo.j2ee.deployment.SwitchingModuleBuilder.addGBeans(SwitchingModuleBuilder.java:174)
at org.apache.geronimo.j2ee.deployment.EARConfigBuilder.buildConfiguration(EARConfigBuilder.java:764)
at org.apache.geronimo.deployment.Deployer.deploy(Deployer.java:255)
at org.apache.geronimo.deployment.Deployer.deploy(Deployer.java:140)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
at java.lang.reflect.Method.invoke(Method.java:611)
at org.apache.geronimo.gbean.runtime.ReflectionMethodInvoker.invoke(ReflectionMethodInvoker.java:34)
at org.apache.geronimo.gbean.runtime.GBeanOperation.invoke(GBeanOperation.java:131)
at org.apache.geronimo.gbean.runtime.GBeanInstance.invoke(GBeanInstance.java:883)
at org.apache.geronimo.kernel.basic.BasicKernel.invoke(BasicKernel.java:245)
at org.apache.geronimo.kernel.KernelGBean.invoke(KernelGBean.java:344)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
at java.lang.reflect.Method.invoke(Method.java:611)
at org.apache.geronimo.gbean.runtime.ReflectionMethodInvoker.invoke(ReflectionMethodInvoker.java:34)
at org.apache.geronimo.gbean.runtime.GBeanOperation.invoke(GBeanOperation.java:131)
at org.apache.geronimo.gbean.runtime.GBeanInstance.invoke(GBeanInstance.java:883)
at org.apache.geronimo.kernel.basic.BasicKernel.invoke(BasicKernel.java:245)
at org.apache.geronimo.system.jmx.MBeanGBeanBridge.invoke(MBeanGBeanBridge.java:172)
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:848)
at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:773)
at javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1438)
at javax.management.remote.rmi.RMIConnectionImpl.access$200(RMIConnectionImpl.java:83)
at javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1276)
at java.security.AccessController.doPrivileged(AccessController.java:284)
at javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1378)
at javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:799)
at sun.reflect.GeneratedMethodAccessor73.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
at java.lang.reflect.Method.invoke(Method.java:611)
at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:322)
at sun.rmi.transport.Transport$1.run(Transport.java:171)
at java.security.AccessController.doPrivileged(AccessController.java:284)
at sun.rmi.transport.Transport.serviceCall(Transport.java:167)
at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:547)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:802)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:661)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:897)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:919)
at java.lang.Thread.run(Thread.java:736)
Caused by: java.lang.ClassNotFoundException: com.sun.faces.config.ConfigureListener
at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:513)
at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:429)
at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:417)
at org.apache.geronimo.hook.equinox.GeronimoClassLoader.loadClass(GeronimoClassLoader.java:85)
at java.lang.ClassLoader.loadClass(ClassLoader.java:626)
at org.eclipse.osgi.internal.loader.BundleLoader.loadClass(BundleLoader.java:345)
at org.eclipse.osgi.framework.internal.core.BundleHost.loadClass(BundleHost.java:229)
at org.eclipse.osgi.framework.internal.core.AbstractBundle.loadClass(AbstractBundle.java:1207)
at org.apache.geronimo.web25.deployment.AbstractWebModuleBuilder.addClass(AbstractWebModuleBuilder.java:670)
at org.apache.geronimo.web25.deployment.AbstractWebModuleBuilder.createWebAppClassFinder(AbstractWebModuleBuilder.java:661)
... 45 more
Предположительно ошибка происходит из-за того, что файлы JAR MyFaces не указаны в пути к классам, однако я не могу понять, в чем причина ошибки, поскольку путь сборки в Eclipse содержит необходимые файлы JAR. Я также попытался скопировать файлы JAR в каталог WEB-INF/lib, но безрезультатно.
На скриншоте ниже показана структура проекта вместе с библиотеками.
Есть ли что-то конкретное, что мне нужно сделать в Eclipse или WASCE, чтобы включить файлы JAR, или проблема кроется в другом месте?
4 ответа
Caused by: java.lang.ClassNotFoundException: com.sun.faces.config.ConfigureListener
Недостающий класс является частью Mojarra, которая на самом деле является конкурентом MyFaces.
Вам не нужен этот класс вообще при использовании MyFaces. Это исключение может иметь следующие возможные причины:
Там определено вручную
<listener>
запись в веб-приложенииweb.xml
илиweb-fragment.xml
любого из развернутых JAR в/WEB-INF/lib
который ссылается на этот класс слушателей для Mojarra.Там где-то свободная Мохарра
.tld
файл в classpath (очень маловероятно, кто когда-либо извлечет файл JAR и поместит его свободное содержимое в classpath?). Файлы TLD автоматически инициализируются и могут содержать<listener>
запись, которая может вызвать авторегистрациюServletContextListener
реализация (например, МохарраConfigureListener
).
Эти конфликты можно исправить, просто удалив их.
Я развернул веб-приложение с Myfaces на сервере Jetty, и для использования Facelets необходимо было использовать прослушиватель и дополнительный параметр init:
<context-param>
<param-name>org.apache.myfaces.FACES_INITIALIZER </param-name>
<param-value>org.apache.myfaces.webapp.FaceletsInitilializer</param-value>
</context-param>
<listener>
<listener-class>org.apache.myfaces.webapp.StartupServletContextListener</listener-class>
</listener>
Я использовал мохарру для компиляции и полагался на Apache Tomcat во время выполнения. Но Tomcat использует реализацию myfaces. Поэтому пришлось включить mojarra impl jar в WEB-INF/lib, чтобы решить эту проблему.
Я был с той же проблемой. Когда я попытался запустить файл.html с Eclipse, используя Tomcat7 в качестве локального сервера, я получил ошибку 404 в браузере. И в консоли Eclipse показывалось сообщение об ошибке "ClassNotFoundException: com.sun.faces.config.ConfigureListener".
Проблема заключалась в библиотеке Mojarra (.jar), которую я использовал в своем проекте Dynamic Web. Я использовал javax.faces-2.3.0-m04.jar.
-> Решение:
Загрузите старую версию в репозитории Mojarra https://maven.java.net/content/repositories/releases/org/glassfish/javax.faces/. В моем случае я скачал версию 2.2.7 (javax.faces-2.2.7.jar).
Затем я создал новый динамический веб-проект в Eclipse, используя JSF v2.0, и назначил ему файл javax.faces-2.2.7.jar в разделе библиотеки.