22

MyFacesv2.1とWebSphereApplicationServer Community Editionv3.0.0.1およびEclipseJunoを使用して単純なJSFWebアプリケーションを作成しようとしていますが、アプリケーションを実行しようとすると、次のエラーが返されます。

    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

MyFaces jarファイルがクラスパスにないためにエラーが発生している可能性がありますが、Eclipseのビルドパスに必要なjarが含まれているため、どこが間違っているのかわかりません。また、jarファイルをWEB-INF / libディレクトリにコピーしようとしましたが、役に立ちませんでした。

以下のスクリーンショットは、プロジェクトの構造とライブラリを示しています。

Eclipseプロジェクトの構造

jarファイルを含めるためにEclipseまたはWASCEで実行する必要がある特定のことはありますか、それとも問題は他の場所にありますか?

4

4 に答える 4

34
Caused by: java.lang.ClassNotFoundException: com.sun.faces.config.ConfigureListener

行方不明のクラスは、実際にはMyFacesの競合相手であるMojarraの一部です。

MyFacesを使用する場合、そのクラスはまったく必要ありません。この例外には、次の原因が考えられます。

  • このMojarra固有のリスナークラスを参照<listener>するwebappweb.xmlまたはweb-fragment.xmlデプロイされたJARのいずれかに手動で定義されたエントリがあります。/WEB-INF/lib

  • クラスパスのどこかに緩いMojarra.tldファイルがあります(JARファイルを抽出し、その緩い内容をクラスパスに入れる可能性はほとんどありません)。TLDファイルは自動初期化され<listener>、実装の自動登録をトリガーできるエントリServletContextListener(MojarraなどConfigureListener)を含めることができます。

これらの競合は、削除するだけで修正できます。

于 2012-08-02T13:08:41.613 に答える
4

JettyサーバーにMyfacesを使用してWebアプリケーションをデプロイしましたが、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>
于 2013-06-05T10:08:29.210 に答える
2

私はコンパイルにmojarra実装を使用し、実行時にapachetomcatに依存していました。ただし、tomcatはmyfaces実装を使用します。そのため、問題を解決するには、WEB-INF/libにmojarraimpljarを含める必要がありました。

于 2014-01-14T17:22:40.547 に答える
1

私も同じ問題を抱えていました。ローカルサーバーとしてTomcat7を使用してEclipseで.htmlファイルを実行しようとすると、ブラウザーで404エラーが発生しました。また、Eclipseのコンソールでは、「ClassNotFoundException:com.sun.faces.config.ConfigureListener」というエラーが表示されていました。

問題は、動的Webプロジェクトで使用していたMojarraライブラリ(.jar)でした。私は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)をダウンロードしました。

次に、JSF v2.0を使用してEclipseで新しい動的Webプロジェクトを作成し、ライブラリセクションのjavax.faces-2.2.7.jarファイルを割り当てました。

于 2015-12-21T21:30:08.930 に答える