CXF:java.lang.ClassNotFoundException:org.apache.cxf.transport.servlet.CXFServlet

时间:2014-03-13 08:17:52

标签: java cxf websphere-8

我正在尝试在WAS 8.0中部署其余的Web服务

应用程序EAR已成功安装。

但是,无论是发布还是在发布后从网络浏览器点击服务,我都会收到以下错误:

[3/13/14 13:42:20:652 IST] 00000024 servlet       E com.ibm.ws.webcontainer.servlet.ServletWrapper run SRVE8052E: Logging ClassNotFoundException
                             java.lang.ClassNotFoundException: class java.lang.ClassNotFoundException: org.apache.cxf.transport.servlet.CXFServlet
at java.beans.Beans.instantiate(Beans.java:190)
at java.beans.Beans.instantiate(Beans.java:75)
at com.ibm.ws.webcontainer.servlet.ServletWrapper$1.run(ServletWrapper.java:1471)
at com.ibm.ws.security.util.AccessController.doPrivileged(AccessController.java:118)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.loadServlet(ServletWrapper.java:1460)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.load(ServletWrapper.java:1358)
at com.ibm.ws.webcontainer.filter.WebAppFilterManager.invokeFilters(WebAppFilterManager.java:982)
at com.ibm.ws.webcontainer.webapp.WebApp.handleRequest(WebApp.java:3751)
at com.ibm.ws.webcontainer.webapp.WebGroup.handleRequest(WebGroup.java:304)
at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:962)
at com.ibm.ws.webcontainer.WSWebContainer.handleRequest(WSWebContainer.java:1662)
at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:195)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:452)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewRequest(HttpInboundLink.java:511)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.processRequest(HttpInboundLink.java:305)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.ready(HttpInboundLink.java:276)
at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.sendToDiscriminators(NewConnectionInitialReadCallback.java:214)
at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.complete(NewConnectionInitialReadCallback.java:113)
at com.ibm.ws.tcp.channel.impl.AioReadCompletionListener.futureCompleted(AioReadCompletionListener.java:165)
at com.ibm.io.async.AbstractAsyncFuture.invokeCallback(AbstractAsyncFuture.java:217)
at com.ibm.io.async.AsyncChannelFuture.fireCompletionActions(AsyncChannelFuture.java:161)
at com.ibm.io.async.AsyncFuture.completed(AsyncFuture.java:138)
at com.ibm.io.async.ResultHandler.complete(ResultHandler.java:204)
at com.ibm.io.async.ResultHandler.runEventProcessingLoop(ResultHandler.java:775)
at com.ibm.io.async.ResultHandler$2.run(ResultHandler.java:905)
at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1690)

然而,包含类的jar即。 cxf-rt-transports-http-2.7.4.jar存在于安装的EAR内的WAR的lib目录中。

问题的原因是什么?

我该如何解决?

更新:我的web.xml如下:

<web-app>
<display-name>MyService</display-name>

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
</context-param>
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<servlet>
    <servlet-name>CXFServlet</servlet-name>
    <display-name>CXF Servlet</display-name>
    <servlet-class>
        org.apache.cxf.transport.servlet.CXFServlet
    </servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>CXFServlet</servlet-name>
    <url-pattern>/rest/*</url-pattern>
</servlet-mapping>

</web-app>

1 个答案:

答案 0 :(得分:1)

我看到你提到“发布”这个词,暗示你可能正在使用Eclipse,或者可能是IBM的RAD甚至是MyEclipse Blue。

如果是真的,请继续阅读......

虽然由m2e / Maven生成的.ear可能在.war文件中存在.jar文件,但m2e-wtp生成的.ear和.war文件可能缺少.jar文件。 m2e-wtp生成的.ear文件是在Eclipse / RAD / MyEclipse Blue中向WAS发布/重新发布应用程序时使用的文件。

尝试从本地WAS中删除该应用,找到该m2e-wtp生成的.ear文件的位置,然后将其删除。从那里,m2e-wtp应该自动生成一个新的.ear文件,如果你清理你的项目(所有相关的pom,耳朵,战争等)

发布应用时,应该找到该类。我过去曾遇到过同样的问题。我的建议解决了这个问题。

除此之外,您可能需要将Classloader策略设置为PARENT_LAST并检查您是否在WAS管理控制台中为整个应用程序(Classloader Policy单选按钮下方的第二组单选按钮)使用单个类加载器。但是,我怀疑Classloader政策是个问题。