JSR352 / JBERET - несовместимый атрибут InnerClasses между "javax.el.BeanELResolver$1" и "java x.el.BeanELResolver"

У меня есть пакетная программа Java на основе JSR325 (обработка чанков), и я пытаюсь работать в режиме Java SE с использованием реализации JBERET. Я придерживаюсь подхода, упомянутого в этом, http://www.mastertheboss.com/javaee/batch-api/running-batch-jobs-in-j2se-applications

Пакетная программа java в режиме Java SE прекрасно работает из Eclipse, но, когда она упакована в Jar-файл и запускается из командной строки, я получаю следующее исключение.

В чем может быть проблема?

INFO: WELD-000119: Not generating any bean definitions from org.h2.value.ValueGeometry because of underlying class loading error: Ty
pe com.vividsolutions.jts.geom.CoordinateSequenceFilter not found.  If this is unexpected, enable DEBUG logging to see the full erro
r.
Exception in thread "main" java.util.ServiceConfigurationError: javax.batch.operations.JobOperator: Provider org.jberet.operations.J
obOperatorImpl could not be instantiated
               at java.util.ServiceLoader.fail(ServiceLoader.java:236)
               at java.util.ServiceLoader.access$100(ServiceLoader.java:193)
               at java.util.ServiceLoader$LazyIterator.next(ServiceLoader.java:389)
               at java.util.ServiceLoader$1.next(ServiceLoader.java:457)
               at javax.batch.runtime.BatchRuntime.getJobOperator(BatchRuntime.java:57)
               at com.citi.Report.App.main(App.java:15)
Caused by: org.jboss.weld.exceptions.DeploymentException: incompatible InnerClasses attribute between "javax.el.BeanELResolver$1" an
d "javax.el.BeanELResolver"
               at org.jboss.weld.executor.AbstractExecutorServices.checkForExceptions(AbstractExecutorServices.java:66)
               at org.jboss.weld.executor.AbstractExecutorServices.invokeAllAndCheckForExceptions(AbstractExecutorServices.java:43)
               at org.jboss.weld.executor.AbstractExecutorServices.invokeAllAndCheckForExceptions(AbstractExecutorServices.java:51)
               at org.jboss.weld.bootstrap.ConcurrentBeanDeployer.createClassBeans(ConcurrentBeanDeployer.java:72)
               at org.jboss.weld.bootstrap.BeanDeployment.createBeans(BeanDeployment.java:260)
               at org.jboss.weld.bootstrap.WeldStartup.deployBeans(WeldStartup.java:351)
               at org.jboss.weld.bootstrap.WeldBootstrap.deployBeans(WeldBootstrap.java:79)
               at org.jboss.weld.bootstrap.api.helpers.ForwardingBootstrap.deployBeans(ForwardingBootstrap.java:63)
               at org.jboss.weld.environment.se.Weld.initialize(Weld.java:143)
               at org.jberet.se.SEArtifactFactory.<init>(SEArtifactFactory.java:31)
               at org.jberet.se.BatchSEEnvironment.getArtifactFactory(BatchSEEnvironment.java:89)
               at org.jberet.operations.JobOperatorImpl.<init>(JobOperatorImpl.java:69)
               at java.lang.J9VMInternals.newInstanceImpl(Native Method)
               at java.lang.Class.newInstance(Class.java:1887)
               at java.util.ServiceLoader$LazyIterator.next(ServiceLoader.java:385)
               ... 3 more
Caused by: java.lang.IncompatibleClassChangeError: incompatible InnerClasses attribute between "javax.el.BeanELResolver$1" and "java
x.el.BeanELResolver"
               at java.lang.Class.getDeclaringClass(Class.java:1034)
               at java.lang.Class.getEnclosingClass(Class.java:2604)
               at org.jboss.weld.util.reflection.Reflections.isNonStaticInnerClass(Reflections.java:388)
               at org.jboss.weld.util.Beans.isTypeManagedBeanOrDecoratorOrInterceptor(Beans.java:486)
               at org.jboss.weld.bootstrap.BeanDeployer.createClassBean(BeanDeployer.java:233)
               at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$2.doWork(ConcurrentBeanDeployer.java:74)
               at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$2.doWork(ConcurrentBeanDeployer.java:72)
               at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
               at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
               at java.util.concurrent.FutureTask.run(FutureTask.java:274)
               at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1157)
               at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:627)
               at java.lang.Thread.run(Thread.java:809)

1 ответ

Я думаю, что проблема заключается в некоторой дискретности в зависимости. Вот подробное обсуждение этой ошибки в целом:

Что вызывает java.lang.IncompatibleClassChangeError?

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