java - 使用omnifaces时 Weld 类加载异常

标签 java jetty omnifaces weld

我一直在 jsf 2.2 应用程序中使用omnifaces,没有出现任何问题,直到我决定从 tomee Web Profiler 迁移到 jetty (9.0.7)。似乎存在一些注释和 CDI 相关问题,导致 Weld (2.1.2.Final) 和 Omnifaces (1.7) 无法很好地配合,我在 Omnifaces 中使用的唯一功能是隐藏 URL 中的扩展名。

项目设置的简要 View :

相关 POM 依赖项:

        <!--OmniFaces-->
    <dependency>
        <groupId>org.omnifaces</groupId>
        <artifactId>omnifaces</artifactId>
        <version>1.7</version>
    </dependency>
 <!--Weld for cdi in jetty--> 
    <dependency>
        <groupId>org.jboss.weld.servlet</groupId>
        <artifactId>weld-servlet</artifactId>
        <version>${weld.version}</version>
        <scope>runtime</scope>
    </dependency>

在 web.xml 中:

    <context-param>
    <param-name>org.omnifaces.FACES_VIEWS_SCAN_PATHS</param-name>
    <param-value>/*.xhtml</param-value>
</context-param>

所有与 Weld 相关的内容都在 override-web.xml 中(在 web.xml 之后解析):

    <!--WELD-->
<listener>
    <listener-class>org.jboss.weld.environment.servlet.Listener</listener-class>
</listener>
<resource-env-ref>
    <resource-env-ref-name>BeanManager</resource-env-ref-name>
    <resource-env-ref-type>
        javax.enterprise.inject.spi.BeanManager
    </resource-env-ref-type>
</resource-env-ref>
   <!--weld complains if the following is not done manually :-S-->
<listener>
    <listener-class>com.sun.faces.config.ConfigureListener</listener-class>
</listener>

我试图让我的应用程序摆脱不必要的 xml 配置,并且到目前为止我已经设法做到了这一点,如果我通过将以下内容放入 beans.xml 来指示 Weld 排除 Omnifaces 中有问题的类:

     <scan>
     <exclude name="org.omnifaces" />
     <exclude name="org.omnifaces.cdi.param.RequestParameterProducer"/>
      <exclude name="org.omnifaces.validator.JsfLabelMessageInterpolator"/>
      <exclude name="org.omnifaces.util.Platform"/>
 </scan>

然后一切都运行良好,omnifaces 完成它的工作,并从 url 中删除扩展名,并且 Weld 不会提示任何事情,所以我的问题是这是否是目前唯一的方法,或者是否有更好的方法解决这个问题而不污染我的 beans.xml?

这是我在执行 mvn jetty:run 时遇到的异常的副本:

 org.jboss.weld.resources.spi.ResourceLoadingException: Exception while loading class org.omnifaces.cdi.param.RequestParameterProducer
    at org.jboss.weld.resources.ClassTransformer.getBackedAnnotatedType(ClassTransformer.java:179) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer.getBackedAnnotatedType(ClassTransformer.java:194) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.BeanDeployer.loadAnnotatedType(BeanDeployer.java:119) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.BeanDeployer.addClass(BeanDeployer.java:96) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$1.doWork(ConcurrentBeanDeployer.java:62) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$1.doWork(ConcurrentBeanDeployer.java:60) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60) [weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53) [weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334) [na:1.7.0_13]
    at java.util.concurrent.FutureTask.run(FutureTask.java:166) [na:1.7.0_13]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) [na:1.7.0_13]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) [na:1.7.0_13]
    at java.lang.Thread.run(Thread.java:722) [na:1.7.0_13]
Caused by: java.lang.TypeNotPresentException: Type javax.validation.ConstraintViolation not present
    at sun.reflect.generics.factory.CoreReflectionFactory.makeNamedType(CoreReflectionFactory.java:117) ~[na:1.7.0_13]
    at sun.reflect.generics.visitor.Reifier.visitClassTypeSignature(Reifier.java:125) ~[na:1.7.0_13]
    at sun.reflect.generics.tree.ClassTypeSignature.accept(ClassTypeSignature.java:49) ~[na:1.7.0_13]
    at sun.reflect.generics.visitor.Reifier.reifyTypeArguments(Reifier.java:68) ~[na:1.7.0_13]
    at sun.reflect.generics.visitor.Reifier.visitClassTypeSignature(Reifier.java:138) ~[na:1.7.0_13]
    at sun.reflect.generics.tree.ClassTypeSignature.accept(ClassTypeSignature.java:49) ~[na:1.7.0_13]
    at sun.reflect.generics.repository.MethodRepository.getReturnType(MethodRepository.java:68) ~[na:1.7.0_13]
    at java.lang.reflect.Method.getGenericReturnType(Method.java:244) ~[na:1.7.0_13]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedMethod.<init>(BackedAnnotatedMethod.java:38) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedMethod.of(BackedAnnotatedMethod.java:32) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.computeValue(BackedAnnotatedType.java:193) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.computeValue(BackedAnnotatedType.java:186) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.util.LazyValueHolder.get(LazyValueHolder.java:35) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$EagerlyInitializedLazyValueHolder.<init>(BackedAnnotatedType.java:154) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.<init>(BackedAnnotatedType.java:186) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.<init>(BackedAnnotatedType.java:186) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType.<init>(BackedAnnotatedType.java:66) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType.of(BackedAnnotatedType.java:47) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer$TransformClassToBackedAnnotatedType.load(ClassTransformer.java:83) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer$TransformClassToBackedAnnotatedType.load(ClassTransformer.java:80) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$LoadingValueReference.loadFuture(LocalCache.java:3589) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$Segment.loadSync(LocalCache.java:2374) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$Segment.lockedGetOrLoad(LocalCache.java:2337) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$Segment.get(LocalCache.java:2252) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache.get(LocalCache.java:3990) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache.getOrLoad(LocalCache.java:3994) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$LocalLoadingCache.get(LocalCache.java:4878) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.util.cache.LoadingCacheUtils.getCacheValue(LoadingCacheUtils.java:52) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.util.cache.LoadingCacheUtils.getCastCacheValue(LoadingCacheUtils.java:80) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer.getBackedAnnotatedType(ClassTransformer.java:175) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    ... 12 common frames omitted
Caused by: java.lang.ClassNotFoundException: javax.validation.ConstraintViolation
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366) ~[na:1.7.0_13]
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355) ~[na:1.7.0_13]
    at java.security.AccessController.doPrivileged(Native Method) ~[na:1.7.0_13]
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354) ~[na:1.7.0_13]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:420) ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:382) ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    at java.lang.Class.forName0(Native Method) ~[na:1.7.0_13]
    at java.lang.Class.forName(Class.java:266) ~[na:1.7.0_13]
    at sun.reflect.generics.factory.CoreReflectionFactory.makeNamedType(CoreReflectionFactory.java:114) ~[na:1.7.0_13]
    ... 41 common frames omitted
20:26:49.562 [weld-worker-1] INFO  org.jboss.weld.Bootstrap - WELD-000119: Not generating any bean definitions from org.omnifaces.validator.JsfLabelMessageInterpolator because of underlying class loading error: Type javax.validation.MessageInterpolator not found.  If this is unexpected, enable DEBUG logging to see the full error.
20:26:49.574 [weld-worker-1] DEBUG org.jboss.weld.Bootstrap - Catching
org.jboss.weld.resources.spi.ResourceLoadingException: Error loading class org.omnifaces.validator.JsfLabelMessageInterpolator
    at org.jboss.weld.resources.AbstractClassLoaderResourceLoader.classForName(AbstractClassLoaderResourceLoader.java:44) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.BeanDeployer.loadClass(BeanDeployer.java:106) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.BeanDeployer.addClass(BeanDeployer.java:94) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$1.doWork(ConcurrentBeanDeployer.java:62) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$1.doWork(ConcurrentBeanDeployer.java:60) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60) [weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53) [weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334) [na:1.7.0_13]
    at java.util.concurrent.FutureTask.run(FutureTask.java:166) [na:1.7.0_13]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) [na:1.7.0_13]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) [na:1.7.0_13]
    at java.lang.Thread.run(Thread.java:722) [na:1.7.0_13]
Caused by: java.lang.NoClassDefFoundError: javax/validation/MessageInterpolator
    at java.lang.ClassLoader.defineClass1(Native Method) ~[na:1.7.0_13]
    at java.lang.ClassLoader.defineClass(ClassLoader.java:791) ~[na:1.7.0_13]
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) ~[na:1.7.0_13]
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:449) ~[na:1.7.0_13]
    at java.net.URLClassLoader.access$100(URLClassLoader.java:71) ~[na:1.7.0_13]
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361) ~[na:1.7.0_13]
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355) ~[na:1.7.0_13]
    at java.security.AccessController.doPrivileged(Native Method) ~[na:1.7.0_13]
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354) ~[na:1.7.0_13]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:420) ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:382) ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    at org.jboss.weld.resources.AbstractClassLoaderResourceLoader.classForName(AbstractClassLoaderResourceLoader.java:40) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    ... 11 common frames omitted
Caused by: java.lang.ClassNotFoundException: javax.validation.MessageInterpolator
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366) ~[na:1.7.0_13]
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355) ~[na:1.7.0_13]
    at java.security.AccessController.doPrivileged(Native Method) ~[na:1.7.0_13]
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354) ~[na:1.7.0_13]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:420) ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:382) ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    ... 23 common frames omitted
20:26:49.769 [weld-worker-2] INFO  org.jboss.weld.Bootstrap - WELD-000119: Not generating any bean definitions from org.omnifaces.util.Platform because of underlying class loading error: Type javax.validation.ValidatorFactory not found.  If this is unexpected, enable DEBUG logging to see the full error.
20:26:49.780 [weld-worker-2] DEBUG org.jboss.weld.Bootstrap - Catching
org.jboss.weld.resources.spi.ResourceLoadingException: Error while loading class org.omnifaces.util.Platform
    at org.jboss.weld.resources.ClassTransformer.getBackedAnnotatedType(ClassTransformer.java:186) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer.getBackedAnnotatedType(ClassTransformer.java:194) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.BeanDeployer.loadAnnotatedType(BeanDeployer.java:119) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.BeanDeployer.addClass(BeanDeployer.java:96) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$1.doWork(ConcurrentBeanDeployer.java:62) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$1.doWork(ConcurrentBeanDeployer.java:60) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60) [weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53) [weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334) [na:1.7.0_13]
    at java.util.concurrent.FutureTask.run(FutureTask.java:166) [na:1.7.0_13]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) [na:1.7.0_13]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) [na:1.7.0_13]
    at java.lang.Thread.run(Thread.java:722) [na:1.7.0_13]
Caused by: java.lang.NoClassDefFoundError: javax/validation/ValidatorFactory
    at java.lang.Class.getDeclaredMethods0(Native Method) ~[na:1.7.0_13]
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2451) ~[na:1.7.0_13]
    at java.lang.Class.getDeclaredMethods(Class.java:1810) ~[na:1.7.0_13]
    at org.jboss.weld.security.GetDeclaredMethodsAction.run(GetDeclaredMethodsAction.java:30) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.security.GetDeclaredMethodsAction.run(GetDeclaredMethodsAction.java:22) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at java.security.AccessController.doPrivileged(Native Method) ~[na:1.7.0_13]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.computeValue(BackedAnnotatedType.java:192) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.computeValue(BackedAnnotatedType.java:186) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.util.LazyValueHolder.get(LazyValueHolder.java:35) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$EagerlyInitializedLazyValueHolder.<init>(BackedAnnotatedType.java:154) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.<init>(BackedAnnotatedType.java:186) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType$BackedAnnotatedMethods.<init>(BackedAnnotatedType.java:186) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType.<init>(BackedAnnotatedType.java:66) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.annotated.slim.backed.BackedAnnotatedType.of(BackedAnnotatedType.java:47) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer$TransformClassToBackedAnnotatedType.load(ClassTransformer.java:83) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer$TransformClassToBackedAnnotatedType.load(ClassTransformer.java:80) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$LoadingValueReference.loadFuture(LocalCache.java:3589) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$Segment.loadSync(LocalCache.java:2374) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$Segment.lockedGetOrLoad(LocalCache.java:2337) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$Segment.get(LocalCache.java:2252) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache.get(LocalCache.java:3990) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache.getOrLoad(LocalCache.java:3994) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at com.google.common.cache.LocalCache$LocalLoadingCache.get(LocalCache.java:4878) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.util.cache.LoadingCacheUtils.getCacheValue(LoadingCacheUtils.java:52) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.util.cache.LoadingCacheUtils.getCastCacheValue(LoadingCacheUtils.java:80) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    at org.jboss.weld.resources.ClassTransformer.getBackedAnnotatedType(ClassTransformer.java:175) ~[weld-servlet-2.1.2.Final.jar:2014-01-09 09:23]
    ... 12 common frames omitted
    Caused by: java.lang.ClassNotFoundException: javax.validation.ValidatorFactory
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366) ~[na:1.7.0_13]
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355) ~[na:1.7.0_13]
    at java.security.AccessController.doPrivileged(Native Method) ~[na:1.7.0_13]
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354) ~[na:1.7.0_13]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:420)     ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    at org.eclipse.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:382)     ~[jetty-webapp-9.0.7.v20131107.jar:9.0.7.v20131107]
    ... 38 common frames omitted

最佳答案

Caused by: java.lang.ClassNotFoundException: javax.validation.ConstraintViolation
Caused by: java.lang.ClassNotFoundException: javax.validation.MessageInterpolator
Caused by: java.lang.ClassNotFoundException: javax.validation.ValidatorFactory

导致这些问题的原因是运行时类路径中不存在 JSR303 Bean Validation API,而那些 OmniFaces CDI bean 期望它存在。这确实是 OmniFaces 依赖文档中的一个不清楚之处。我们将对此进行研究。

除了明确排除这些类被扫描为 CDI 托管 bean 之外,您还可以考虑实际安装 JSR303 API,如果需要,还可以考虑在 Jetty 中安装 JSR303 实现以及 CDI API/impl。这个答案在 how to install CDI in Tomcat也适用于您的 Jetty 案例。

关于java - 使用omnifaces时 Weld 类加载异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22095634/

相关文章:

elasticsearch - 将Elasticsearch与Jetty Jersey 一起使用

java - 在 OSGi 中从 ReSTLet 启动 Jetty

使用 arquillian+omnifaces 运行测试时出现 java.util.ServiceConfigurationError

jsf - 如何在一个 EAR 中的两个 WAR 中使用 OmniFaces 1.6?

java - 将 Jetty 与 JAX-RS-Jersey 集成

jsf - 为什么找不到我的功能?

java - 亚马逊云驱动器与 android 的集成

java - 尝试构建 APK 时,Gradle Build 因意外错误而失败

java - java中的Aes解密 - 填充问题

java - 为什么对 UUID.randomUUID() 的初始调用很慢?