简体   繁体   中英

JSR352 / JBERET - incompatible InnerClasses attribute between “javax.el.BeanELResolver$1” and “java x.el.BeanELResolver”

I have a JSR325 (Chunk processing) based java batch program and trying to run in Java SE mode using JBERET implementation. I am following the approach mentioned in this this http://www.mastertheboss.com/javaee/batch-api/running-batch-jobs-in-j2se-applications

The java batch program in Java SE mode runs fine from Eclipse but, when packaged as a Jar and run from command prompt, am getting the following exception.

What could be the problem ?

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)

I think the problem lies in some discrepency in dependencies. Here is a detailed discussion on this error in general:

What causes java.lang.IncompatibleClassChangeError?

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM