[英]Apache CXF Logging
我通过Apache CXF framework
Web服务与我的服务器 - 客户端通信有一些问题。 我想将服务器错误记录到外部文件而不是终端。 服务器的代码片;
server= new JaxwsNotificationBroker("Hello",..);
server.setAddress("http://localhost:" + brokerPort + "/wsn/NotificationBroker");
我试着用它来记录;
server.getInInterceptors().add(new LoggingInInterceptor());
server.getOutInterceptors().add(new LoggingOutInterceptor());
但它给出了错误The method getInInterceptors() is undefined for the type JaxwsNotificationBroker
。
是否有任何方法可以记录JaxwsNotificationBroker
的错误?
谢谢
您可以在cxf:bus
添加loggingInInterceptor
和logOutInterceptor
<cxf:bus>
<cxf:ininterceptors>
<ref bean="loggingInInterceptor" />
</cxf:ininterceptors>
<cxf:outinterceptors>
<ref bean="logOutInterceptor" />
</cxf:outinterceptors>
</cxf:bus>
如果您使用的是spring,请将其添加到spring配置文件中:
<cxf:bus>
<cxf:features>
<cxf:logging />
</cxf:features>
</cxf:bus>
不要忘记添加cxf名称空间为
xmlns:cxf="http://cxf.apache.org/core"
如果使用log4j进行日志记录,则必须将META-INF / cxf / org.apache.cxf.Logger文件放入类路径中,并将“org.apache.cxf.common.logging.Log4jLogger”类名作为单行添加否则cxf将使用JavaTM 2平台的核心日志记录工具。
出于某种原因,gnodet希望将所有WS-N内容尽可能独立于CXF,并且只依赖于纯JAX-WS的东西。 因此,像CXF拦截器这样的好方法是不可能的。 :-(
查看代码,现在唯一的选择是编写一个JaxwsEndpointManager的子类,它将调用super.register方法,然后将其转换为CXF EndpointImpl,并在那里设置拦截器。 不太理想。 :-(
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.