Axis2 记录 SOAP 请求和带有 logback 的响应被截断为 4000 个字符(字节)
Axis2 logging SOAP request and response with logback truncates to 4000 characters(bytes)
我们正在尝试使用 logback 和以下配置记录 Axis2 SOAP 日志消息:
<!-- Axis client appender -->
<appender name="AxisLogging" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>INFO</level>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>DEBUG</level>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>TRACE</level>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<File>log/axis-client.log</File>
<rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
<FileNamePattern>log/axis-client.%i.log</FileNamePattern>
<MinIndex>1</MinIndex>
<MaxIndex>5</MaxIndex>
</rollingPolicy>
<triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
<MaxFileSize>100MB</MaxFileSize>
</triggeringPolicy>
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="ch.qos.logback.classic.PatternLayout">
<Pattern>[%date{yyyy-MM-dd HH:mm:ss.SSS zZ}] %-5level [%mdc{requestsite}] [%mdc{session.id}] "%thread" %msg %ex%n</Pattern>
</layout>
</encoder>
</appender>
<logger name="httpclient.wire.content">
<appender-ref ref="AxisLogging"/>
</logger>
长请求和响应的日志消息 XML 被截断为 4000 个字符,并分布在多个日志行中。
有什么方法可以配置 logback 以在一个日志行中记录整个 XML?
谢谢!
您确定限制在 logback 中吗?也许限制在 axis2 中。
注意:在此示例中,限制在 apache CXF 库中。
Text length limit in logback logging
这就是我通常记录肥皂消息的方式。不过确实需要一些编程。
String request = stub._getServiceClient().getLastOperationContext().getMessageContext("Out")
.getEnvelope().toString());
String response = stub._getServiceClient().getLastOperationContext().getMessageContext("In")
.getEnvelope().toString());
如果您将这些变量写入日志,那么应该没有问题。
显然这是 ReaderConfig.java (com.ctc.wstx.api.ReaderConfig.java) 的问题,它负责读取(和记录 Web 服务响应)。如您所见:
https://github.com/FasterXML/woodstox/blob/master/src/main/java/com/ctc/wstx/api/ReaderConfig.java
在由com.ctc.wstx.stax.WstxInputFactory启动的服务器上调用的方法createFullDefaults()中,Reader被构造为固定缓冲区长度为4000。
因此,如果您希望在一行中包含完整的 Axis2 响应 XML 消息,那么使用自定义代码记录是唯一的解决方案。
我们正在尝试使用 logback 和以下配置记录 Axis2 SOAP 日志消息:
<!-- Axis client appender -->
<appender name="AxisLogging" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>INFO</level>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>DEBUG</level>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>TRACE</level>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<File>log/axis-client.log</File>
<rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
<FileNamePattern>log/axis-client.%i.log</FileNamePattern>
<MinIndex>1</MinIndex>
<MaxIndex>5</MaxIndex>
</rollingPolicy>
<triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
<MaxFileSize>100MB</MaxFileSize>
</triggeringPolicy>
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="ch.qos.logback.classic.PatternLayout">
<Pattern>[%date{yyyy-MM-dd HH:mm:ss.SSS zZ}] %-5level [%mdc{requestsite}] [%mdc{session.id}] "%thread" %msg %ex%n</Pattern>
</layout>
</encoder>
</appender>
<logger name="httpclient.wire.content">
<appender-ref ref="AxisLogging"/>
</logger>
长请求和响应的日志消息 XML 被截断为 4000 个字符,并分布在多个日志行中。 有什么方法可以配置 logback 以在一个日志行中记录整个 XML?
谢谢!
您确定限制在 logback 中吗?也许限制在 axis2 中。 注意:在此示例中,限制在 apache CXF 库中。
Text length limit in logback logging
这就是我通常记录肥皂消息的方式。不过确实需要一些编程。
String request = stub._getServiceClient().getLastOperationContext().getMessageContext("Out")
.getEnvelope().toString());
String response = stub._getServiceClient().getLastOperationContext().getMessageContext("In")
.getEnvelope().toString());
如果您将这些变量写入日志,那么应该没有问题。
显然这是 ReaderConfig.java (com.ctc.wstx.api.ReaderConfig.java) 的问题,它负责读取(和记录 Web 服务响应)。如您所见:
https://github.com/FasterXML/woodstox/blob/master/src/main/java/com/ctc/wstx/api/ReaderConfig.java
在由com.ctc.wstx.stax.WstxInputFactory启动的服务器上调用的方法createFullDefaults()中,Reader被构造为固定缓冲区长度为4000。
因此,如果您希望在一行中包含完整的 Axis2 响应 XML 消息,那么使用自定义代码记录是唯一的解决方案。