CXF客户端报错:An error was discovered processing the header

caicheng_toto 2016-10-21 11:25:26
先说下背景:WAS 8.0.0.7 \ JDK1.6 \ cxf2.4.1。有两块对接接口,配置一样,但是上一个接口运行正常,这次开发的接口就遇到报错情况了。下面直接贴代码:
beansClient.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jaxws="http://cxf.apache.org/jaxws"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://cxf.apache.org/jaxws http://cxf.apache.org/schemas/jaxws.xsd">

<bean id="clientXs" class="com.test.iae.client.IDataExchangeServiceXs" factory-bean="clientFactoryXs" factory-method="create">
</bean>
<bean id="clientFactoryXs" class="org.apache.cxf.jaxws.JaxWsProxyFactoryBean">
<property name="serviceClass" value="com.test.iae.client.IDataExchangeServiceXs"></property>
<property name="address" value="http://*********/IAE_XS/" />
<property name="outInterceptors">
<list>
<ref bean="wss4jOutConfigurationXs" />
<bean class="com.test.iae.client.AddHeaderInterceptor_XS" />
</list>
</property>
<property name="inInterceptors">
<list>
<ref bean="wss4jInConfigurationXs" />
</list>
</property>
<property name="features">
<bean class="org.apache.cxf.feature.LoggingFeature"></bean>
</property>
</bean>
<bean id="wss4jOutConfigurationXs" class="org.apache.cxf.ws.security.wss4j.WSS4JOutInterceptor">
<property name="properties">
<map>
<!-- Signature Encrypt -->
<entry key="action" value="Signature Encrypt" />

<entry key="user" value="datchangeaegon" />
<!-- <entry key="signatureKeyIdentifier" value="IssuerSerial" /> -->
<entry key="signatureUser" value="datchangeaegon"/>
<entry key="signaturePropFile" value="etc/xs_client.properties" /> <!-- 客户端签名配置 -->

<entry key="encryptionUser" value="datchangeebt"></entry>
<entry key="encryptionPropFile" value="etc/xs_client.properties"></entry> <!-- 客户端加解密配置 -->
<!-- <entry key="encryptionKeyIdentifier" value="IssuerSerial"></entry> -->
<entry>
<key>
<value>passwordCallbackRef</value>
</key>
<ref bean="passwordCallbackXs" />
</entry>
</map>
</property>
</bean>
<bean id="wss4jInConfigurationXs" class="org.apache.cxf.ws.security.wss4j.WSS4JInInterceptor">
<property name="properties">
<map>
<entry key="action" value="Signature Encrypt" />
<entry key="decryptionPropFile" value="etc/xs_client.properties"></entry>
<entry key="signaturePropFile" value="etc/xs_client.properties" />
<entry>
<key>
<value>passwordCallbackRef</value>
</key>
<ref bean="passwordCallbackXs" />
</entry>
</map>
</property>
</bean>
<bean id="passwordCallbackXs" class="com.test.iae.client.ClientPasswordCallback" />
</beans>

这个错网上很多相关讨论,但是没有一个能说明怎么解决问题,看着header的提示所以觉得应该跟写SOAP头有关系,贴出HeaderInterceptor代码:
public class AddHeaderInterceptor_XS extends SoapHeaderOutFilterInterceptor {
public void handleMessage(SoapMessage message) throws Fault {
try {
Header dummyHeader = new SoapHeader(new QName("", "insuCompCode"), "1060", new JAXBDataBinding(String.class));
message.getHeaders().add(dummyHeader);
} catch (Exception e) {
e.printStackTrace();
}
}
}

DEBUG的时候是看得到soap头生成并且add到message了。
另外补充个一点,在本地tomcat上运行时正常的,但是因为网络环境问题连不到目标地址,所以tomcat下只会报connection out time。这点就很奇怪,首先为什么tomcat下不会报CXF相关错误而WAS会。再者就是为啥WAS下为啥前一个接口可以正常运行而新开发的不行,配置都是照搬的一套,请问是跟server提供的webservice接口类有关系吗?
public interface IDataExchangeServiceXs 
{
@ResponseWrapper(targetNamespace = "http://service.dataexchange.platform.ebt.com/")
@RequestWrapper(targetNamespace = "http://service.dataexchange.platform.ebt.com/")
@WebResult(name = "return", targetNamespace = "")
/**
* @param paramArrayOfByte1 业务类型数据
* @param paramArrayOfByte2 目前此参数没有
* @return byte [] 压缩文件流
*/
public byte[] doExchange(@WebParam(name="arg0", targetNamespace="") byte[] c,
@WebParam(name="arg1", targetNamespace="") byte[] paramArrayOfByte2);
}



错误信息:
DataExchangeClient.dataExchangeForXS error:javax.xml.ws.soap.SOAPFaultException: An error was discovered processing the <wsse:Security> header.
at org.apache.cxf.jaxws.JaxWsClientProxy.invoke(JaxWsClientProxy.java:146)
at com.sun.proxy.$Proxy2018.doExchange(Unknown Source)
at com.aegon_cnooc.iae.client.XsDataExchangeClient.dataExchangeForXS(XsDataExchangeClient.java:78)
at com.aegon_cnooc.iae.client.servlet.XsOnlineSendDataServlet.doPost(XsOnlineSendDataServlet.java:50)
at com.aegon_cnooc.iae.client.servlet.ControlServlet.doPost(ControlServlet.java:62)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:595)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:668)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1230)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:779)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:478)
at com.ibm.ws.webcontainer.servlet.ServletWrapperImpl.handleRequest(ServletWrapperImpl.java:178)
at com.ibm.ws.webcontainer.filter.WebAppFilterManager.invokeFilters(WebAppFilterManager.java:1071)
at com.ibm.ws.webcontainer.webapp.WebApp.handleRequest(WebApp.java:3763)
at com.ibm.ws.webcontainer.webapp.WebGroup.handleRequest(WebGroup.java:304)
at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:976)
at com.ibm.ws.webcontainer.WSWebContainer.handleRequest(WSWebContainer.java:1662)
at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:200)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:453)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewRequest(HttpInboundLink.java:515)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.processRequest(HttpInboundLink.java:306)
at com.ibm.ws.http.channel.inbound.impl.HttpICLReadCallback.complete(HttpICLReadCallback.java:84)
at com.ibm.ws.tcp.channel.impl.AioReadCompletionListener.futureCompleted(AioReadCompletionListener.java:175)
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:1700)
Caused by: org.apache.cxf.binding.soap.SoapFault: An error was discovered processing the <wsse:Security> header.
at org.apache.cxf.binding.soap.interceptor.Soap11FaultInInterceptor.unmarshalFault(Soap11FaultInInterceptor.java:75)
at org.apache.cxf.binding.soap.interceptor.Soap11FaultInInterceptor.handleMessage(Soap11FaultInInterceptor.java:46)
at org.apache.cxf.binding.soap.interceptor.Soap11FaultInInterceptor.handleMessage(Soap11FaultInInterceptor.java:35)
at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:263)
at org.apache.cxf.interceptor.AbstractFaultChainInitiatorObserver.onMessage(AbstractFaultChainInitiatorObserver.java:104)
at org.apache.cxf.binding.soap.interceptor.CheckFaultInterceptor.handleMessage(CheckFaultInterceptor.java:69)
at org.apache.cxf.binding.soap.interceptor.CheckFaultInterceptor.handleMessage(CheckFaultInterceptor.java:34)
at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:263)
at org.apache.cxf.endpoint.ClientImpl.onMessage(ClientImpl.java:762)
at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.handleResponseInternal(HTTPConduit.java:1582)
at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.handleResponse(HTTPConduit.java:1467)


还请大牛们帮忙,已经困扰了一周了,如果信息不够我再贴,先谢过各位了!
...全文
1213 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
xuan.ye 2016-11-22
  • 打赏
  • 举报
回复
cxf的jar包 几十个吧,希望你一个都没有落掉,可惜还不支持maven。
caicheng_toto 2016-10-21
  • 打赏
  • 举报
回复
自己顶上来。大牛呢?

12,162

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 Web Services
社区管理员
  • Web Services社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧