使用CXF 2.7.5出現的java.lang.RuntimeException: Cannot create a secure XMLInputFactory錯誤解決


昨天啟動工程測試webservice服務,結果發現服務一調用就報java.lang.RuntimeException: Cannot create a secure XMLInputFactory

java.lang.RuntimeException: Cannot create a secure XMLInputFactory
	at org.apache.cxf.staxutils.StaxUtils.createXMLInputFactory(StaxUtils.java:300)
	at org.apache.cxf.staxutils.StaxUtils.getXMLInputFactory(StaxUtils.java:255)
	at org.apache.cxf.staxutils.StaxUtils.createXMLStreamReader(StaxUtils.java:1346)
	at org.apache.cxf.interceptor.StaxInInterceptor.handleMessage(StaxInInterceptor.java:112)
	at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:271)
	at org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:121)
	at org.apache.cxf.transport.http.AbstractHTTPDestination.invoke(AbstractHTTPDestination.java:239)
	at org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:223)
	at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:203)
	at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:137)
	at org.apache.cxf.transport.servlet.CXFNonSpringServlet.invoke(CXFNonSpringServlet.java:158)
	at org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:243)
	at org.apache.cxf.transport.servlet.AbstractHTTPServlet.doPost(AbstractHTTPServlet.java:163)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
	at org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:219)
	at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:227)
	at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:125)
	at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:301)

  原先項目是2.7.4的一直是好的,之后由於maven編譯的關系,換成了2.7.5就發現報了這個錯,上網搜來搜去大家無非說是缺了一些jar包,比如:

woodstox-core-asl-4.2.0.jar

stax2-api-3.1.1.jar

  但是我這里都有,然后有人翻原代碼說加參數什么的,我當時就想:需要這么麻煩么,而且我也看了反編譯的代碼,沒看出什么有什么問題。然后又有人說拿官方cxf-2.7.5.zip中全部的jar包來跑就ok了。

  搜了一圈,都沒有理想的解答,沒辦法,只好自己想辦法。最后發現其實答案很簡單:

  因為我這個是weblogic上報的錯,因為我們生產環境是weblogic我也就沒想着去tomcat去驗證,不過料想在tomcat上應該沒問題。

  weblogic的話,我們知道它會優先加載自己的類庫,為了防止沖突,weblogic在xml里可以配置優先加載用戶的。想到這里,我就打開了weblogic的modules看了一下,果然~~~

果然weblogic自帶了stax,所以我懷疑應該就是這里導致了沖突

於是我就在weblogic.xml里加入了

<wls:package-name>org.codehaus.stax2.*</wls:package-name>

為了防止woodstox包沖突,我干脆把woodstox的com.ctc.wstx也加了上去,如上圖最后一行

加完測試~~~ok一切正常了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM