2017-02-20 9 views
0

У меня есть приложение, развернутое в Tomcat 8.5.11 через Arquillian (1.1.12.Final), где запрашивается веб-сервис. Приложение имеет Apache CXF 3.1.10 в качестве предоставленной зависимости; все cxf и весенние JAR были добавлены в каталог библиотек endorsed на Tomcat (я проверил, что все одобренные JAR загружены правильно).Tomcat8 org.apache.cxf.BusFactory.getBusFactoryClass Не удалось определить имя класса реализации BusFactory

Несмотря на это, я столкнулся с вышеупомянутым сообщением об ошибке. Соответствующие биты являются StackTrace

java.lang.NullPointerException 
    at org.apache.cxf.BusFactory.getBusFactoryClass(BusFactory.java:397) 
    at org.apache.cxf.BusFactory.newInstance(BusFactory.java:317) 
    at org.apache.cxf.BusFactory.newInstance(BusFactory.java:304) 
    at org.apache.cxf.BusFactory.getDefaultBus(BusFactory.java:107) 
    at org.apache.cxf.BusFactory.createThreadBus(BusFactory.java:244) 
    at org.apache.cxf.BusFactory.getThreadDefaultBus(BusFactory.java:228) 
    at org.apache.cxf.jaxws.ServiceImpl.initialize(ServiceImpl.java:135) 
    at org.apache.cxf.jaxws.ServiceImpl.<init>(ServiceImpl.java:129) 
    at org.apache.cxf.jaxws.spi.ProviderImpl.createServiceDelegate(ProviderImpl.java:82) 
    at javax.xml.ws.Service.<init>(Service.java:77) 

[надрез]

java.lang.NullPointerException 
    at org.apache.cxf.bus.extension.ExtensionManagerImpl.load(ExtensionManagerImpl.java:166) 
    at org.apache.cxf.bus.extension.ExtensionManagerImpl.load(ExtensionManagerImpl.java:160) 
    at org.apache.cxf.bus.extension.ExtensionManagerImpl.load(ExtensionManagerImpl.java:107) 
    at org.apache.cxf.bus.extension.ExtensionManagerBus.<init>(ExtensionManagerBus.java:178) 
    at org.apache.cxf.bus.extension.ExtensionManagerBus.<init>(ExtensionManagerBus.java:185) 
    at org.apache.cxf.bus.CXFBusFactory.createBus(CXFBusFactory.java:40) 
    at org.apache.cxf.bus.CXFBusFactory.createBus(CXFBusFactory.java:36) 
    at org.apache.cxf.bus.CXFBusFactory.createBus(CXFBusFactory.java:32) 
    at org.apache.cxf.bus.spring.SpringBusFactory.createBus(SpringBusFactory.java:146) 
    at org.apache.cxf.bus.spring.SpringBusFactory.createBus(SpringBusFactory.java:122) 
    at org.apache.cxf.bus.spring.SpringBusFactory.createBus(SpringBusFactory.java:94) 
    at org.apache.cxf.bus.spring.SpringBusFactory.createBus(SpringBusFactory.java:83) 
    at org.apache.cxf.BusFactory.getDefaultBus(BusFactory.java:107) 
    at org.apache.cxf.BusFactory.createThreadBus(BusFactory.java:244) 
    at org.apache.cxf.BusFactory.getThreadDefaultBus(BusFactory.java:228) 
    at org.apache.cxf.jaxws.ServiceImpl.initialize(ServiceImpl.java:135) 
    at org.apache.cxf.jaxws.ServiceImpl.<init>(ServiceImpl.java:129) 
    at org.apache.cxf.jaxws.spi.ProviderImpl.createServiceDelegate(ProviderImpl.java:82) 
    at javax.xml.ws.Service.<init>(Service.java:77) 

NPE происходит во время инициализации веб-сервиса. Код, который терпит неудачу в

// org.apache.cxf.bus.extension.ExtensionManagerImpl 
final void load(String resource) throws IOException { 
    if (loader != getClass().getClassLoader()) { 
     load(resource, getClass().getClassLoader()); 
    } 
    load(resource, loader); 
} 

Оказывается, что вызов getClass().getClassLooader() возвращается null. Я был озадачен этим результатом только для того, чтобы узнать getClass().getClassLoader() is null, why?, который до сих пор не имеет для меня смысла, поскольку я думаю, что это означает, что CXF был загружен с помощью bootclasspath (!?!).

ответ

0

Проблема была вызвана размещением банки CXF в $CATALINA_HOME/endoresed. Это неправильное расположение для размещения баннеров, которые являются общими для всех веб-приложений. Как пояснялось в разделе http://tomcat.apache.org/tomcat-7.0-doc/class-loader-howto.html в разделе «XML Parsers and Java».

Смежные вопросы