Java JAX-WS Web服务客户端:如何记录日志请求&响应xml?

时间:2010-05-11 06:39:47

标签: java web-services jax-ws

我创建了一个实现LoggingHandler

SOAPHandler<SOAPMessageContext>实现

它应该在handleMessage触发时记录(在我的情况下永远不会被调用)

MyService service = new MyService();
MyServicePort port = service.getPortType();

现在我试试这个:

BindingProvider bindingProvider = (BindingProvider)port;
bindingProvider.getBinding().getHandlerChain().add(new LoggingHandler());

我没有看到任何请求/响应xml。

你能建议任何解决方案吗?也许有另一种方式来查看输出并请求XML?

3 个答案:

答案 0 :(得分:23)

如果您使用此方法,它将开始工作:

binding.setHandlerChain(handlerList);

因此,首先使用

初始化此列表
binding.getHandlerChain();

然后将您的元素添加到列表中,毕竟

setHandlerChain();

答案 1 :(得分:2)

您可以在log4j.xml文件中添加记录器:

<!-- Log WebService's inputs and outputs -->
<logger name="org.apache.cxf.interceptor">
    <level value="INFO" />
    <appender-ref ref="[YOUR_LOGGER]" />
</logger>

答案 2 :(得分:1)

如果有人想知道@EugeneP的“为什么”出色的答案。

在接口javax.xml.ws.Binding中,有以下注释。

/**
 * Gets a copy of the handler chain for a protocol binding instance.
 * If the returned chain is modified a call to 
 <code>setHandlerChain</code>
 * is required to configure the binding instance with the new chain.
 *
 *  @return java.util.List&lt;Handler> Handler chain
 */
 public java.util.List<javax.xml.ws.handler.Handler> getHandlerChain();

因此getHandlerChain()方法返回List的副本而不是列表本身。所以你必须使用setHandlerChain来更新实际的List。