12,162
社区成员
发帖
与我相关
我的任务
分享
<?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>
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();
}
}
}
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)