Doug Holubek created PHOENIX-3261:
-------------------------------------
Summary: Phoenix includes a JAXB version that conflicts with CXF
3.0.x dependencies
Key: PHOENIX-3261
URL: https://issues.apache.org/jira/browse/PHOENIX-3261
Project: Phoenix
Issue Type: Bug
Affects Versions: 4.4.0
Reporter: Doug Holubek
Priority: Blocker
Phoenix jars seem to bundle an older version of JAXB. The DEPENDENCIES file in
the .jar's META-INF seems to show that Phoenix is including jaxb-impl-2.2.3-1.
According to This CXF jira issue
https://issues.apache.org/jira/browse/CXF-5894
(with same exception stack trace) CXF needs 2.10.x or higher. Since Phoenix is
built with the classes inside the jar I can't exclude Phoenix's older version
of JAXB via Maven.
(exert from DEPEDENCIES file inside Phoenix jar - seems to be the same across
many Phoenix versions.)
From: 'Oracle Corporation' (http://www.oracle.com/)
- jersey-client (https://jersey.java.net/jersey-client/)
com.sun.jersey:jersey-client:bundle:1.9
License: CDDL 1.1 (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
License: GPL2 w/ CPE (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
- jersey-core (https://jersey.java.net/jersey-core/)
com.sun.jersey:jersey-core:bundle:1.9
License: CDDL 1.1 (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
License: GPL2 w/ CPE (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
- jersey-json (https://jersey.java.net/jersey-json/)
com.sun.jersey:jersey-json:bundle:1.9
License: CDDL 1.1 (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
License: GPL2 w/ CPE (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
- jersey-server (https://jersey.java.net/jersey-server/)
com.sun.jersey:jersey-server:bundle:1.9
License: CDDL 1.1 (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
License: GPL2 w/ CPE (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
- jersey-guice (https://jersey.java.net/jersey-contribs/jersey-guice/)
com.sun.jersey.contribs:jersey-guice:jar:1.9
License: CDDL 1.1 (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
License: GPL2 w/ CPE (http://glassfish.java.net/public/CDDL+GPL_1_1.html)
- JAXB RI (http://jaxb.java.net/) com.sun.xml.bind:jaxb-impl:jar:2.2.3-1
License: CDDL 1.1 (https://glassfish.java.net/public/CDDL+GPL_1_1.html)
License: GPL2 w/ CPE (https://glassfish.java.net/public/CDDL+GPL_1_1.html)
- JAXB API bundle for GlassFish V3 (https://jaxb.dev.java.net/)
javax.xml.bind:jaxb-api:jar:2.2.2
License: CDDL 1.1
(https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html) License: GPL2 w/
CPE (https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html)
When trying to initialize a soap client with CXF 3.0.9 I get the following
exception when staring my web application.
Caused by: java.lang.NoSuchFieldError: REFLECTION
at
com.sun.xml.bind.v2.model.impl.RuntimeModelBuilder.<init>(RuntimeModelBuilder.java:93)
at
com.sun.xml.bind.v2.runtime.JAXBContextImpl.getTypeInfoSet(JAXBContextImpl.java:473)
at
com.sun.xml.bind.v2.runtime.JAXBContextImpl.<init>(JAXBContextImpl.java:319)
at
com.sun.xml.bind.v2.runtime.JAXBContextImpl$JAXBContextBuilder.build(JAXBContextImpl.java:1170)
at
com.sun.xml.bind.v2.ContextFactory.createContext(ContextFactory.java:145)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at javax.xml.bind.ContextFinder.newInstance(ContextFinder.java:248)
at javax.xml.bind.ContextFinder.newInstance(ContextFinder.java:235)
at javax.xml.bind.ContextFinder.find(ContextFinder.java:432)
at javax.xml.bind.JAXBContext.newInstance(JAXBContext.java:637)
at
org.apache.cxf.common.jaxb.JAXBContextCache$2.run(JAXBContextCache.java:347)
at
org.apache.cxf.common.jaxb.JAXBContextCache$2.run(JAXBContextCache.java:345)
at java.security.AccessController.doPrivileged(Native Method)
at
org.apache.cxf.common.jaxb.JAXBContextCache.createContext(JAXBContextCache.java:345)
at
org.apache.cxf.common.jaxb.JAXBContextCache.getCachedContextAndSchemas(JAXBContextCache.java:246)
at
org.apache.cxf.jaxb.JAXBDataBinding.createJAXBContextAndSchemas(JAXBDataBinding.java:472)
at
org.apache.cxf.jaxb.JAXBDataBinding.initialize(JAXBDataBinding.java:327)
at
org.apache.cxf.service.factory.AbstractServiceFactoryBean.initializeDataBindings(AbstractServiceFactoryBean.java:86)
at
org.apache.cxf.wsdl.service.factory.ReflectionServiceFactoryBean.buildServiceFromClass(ReflectionServiceFactoryBean.java:467)
at
org.apache.cxf.jaxws.support.JaxWsServiceFactoryBean.buildServiceFromClass(JaxWsServiceFactoryBean.java:712)
at
org.apache.cxf.wsdl.service.factory.ReflectionServiceFactoryBean.initializeServiceModel(ReflectionServiceFactoryBean.java:527)
at
org.apache.cxf.wsdl.service.factory.ReflectionServiceFactoryBean.create(ReflectionServiceFactoryBean.java:261)
at
org.apache.cxf.jaxws.support.JaxWsServiceFactoryBean.create(JaxWsServiceFactoryBean.java:215)
at
org.apache.cxf.frontend.AbstractWSDLBasedEndpointFactory.createEndpoint(AbstractWSDLBasedEndpointFactory.java:102)
at
org.apache.cxf.frontend.ClientFactoryBean.create(ClientFactoryBean.java:91)
at
org.apache.cxf.frontend.ClientProxyFactoryBean.create(ClientProxyFactoryBean.java:157)
at
org.apache.cxf.jaxws.JaxWsProxyFactoryBean.create(JaxWsProxyFactoryBean.java:142)
at
org.apache.cxf.jaxws.spring.JaxWsProxyFactoryBeanDefinitionParser$JAXWSSpringClientProxyFactoryBean.create(JaxWsProxyFactoryBeanDefinitionParser.java:79)
at
org.apache.cxf.jaxws.spring.JaxWsProxyFactoryBeanDefinitionParser$JAXWSSpringClientProxyFactoryBean.getObject(JaxWsProxyFactoryBeanDefinitionParser.java:83)
at
org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:168)
... 49 more
As a side note there is a similar problem here:
https://issues.apache.org/jira/browse/MAPREDUCE-6042?jql=text%20~%20%22jaxb%20conflict%22
...does Phoenix need jaxb to build? Can it be removed? If not can jaxb be a
dependency in its pom.xml instead of included in a monolithic jar?
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)