Java 如何使用spring记录RestTemplate请求和响应?

Java 如何使用spring记录RestTemplate请求和响应?,java,spring,logging,spring-rest,Java,Spring,Logging,Spring Rest,我正在使用spring和restemplate执行GET查询 如何在每次请求时自动将任何请求和响应数据记录到日志文件中?您可以在春季使用clienthttpprequestinterceptor实现这一点。 您必须覆盖接口ClientHttpRequestInterceptor的方法intercept 下面是代码片段: @Component public class LogRequestResponseFilter implements ClientHttpRequestInterceptor

我正在使用
spring
restemplate
执行
GET
查询


如何在每次请求时自动将任何请求和响应数据记录到日志文件中?

您可以在春季使用clienthttpprequestinterceptor实现这一点。 您必须覆盖接口ClientHttpRequestInterceptor的方法intercept

下面是代码片段:

@Component
public class LogRequestResponseFilter implements ClientHttpRequestInterceptor {

private static final Logger logger=LoggerFactory.getLogger(LogRequestResponseFilter.class);

   @Override
   public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution)
         throws IOException {

      traceRequest(request, body);
      ClientHttpResponse clientHttpResponse = execution.execute(request, body);
      traceResponse(clientHttpResponse);

      return clientHttpResponse;
   } 

 private void traceRequest(HttpRequest request, byte[] body) throws IOException {
      logger.debug("request URI : " + request.getURI());
      logger.debug("request method : " + request.getMethod());
      logger.debug("request body : " + getRequestBody(body));
   }

   private String getRequestBody(byte[] body) throws UnsupportedEncodingException {
      if (body != null && body.length > 0) {
         return (new String(body, "UTF-8"));
      } else {
         return null;
      }
   }


  private void traceResponse(ClientHttpResponse response) throws IOException {
      String body = getBodyString(response);
      logger.debug("response status code: " + response.getStatusCode());
      logger.debug("response status text: " + response.getStatusText());
      logger.debug("response body : " + body);
   }

   private String getBodyString(ClientHttpResponse response) {
      try {
         if (response != null && response.getBody() != null) {// &&
                                                              // isReadableResponse(response))
                                                              // {
            StringBuilder inputStringBuilder = new StringBuilder();
            BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(response.getBody(), StandardCharsets.UTF_8));
            String line = bufferedReader.readLine();
            while (line != null) {
               inputStringBuilder.append(line);
               inputStringBuilder.append('\n');
               line = bufferedReader.readLine();
            }
            return inputStringBuilder.toString();
         } else {
            return null;
         }
      } catch (IOException e) {
         logger.error(e.getMessage(), e);
         return null;
      }
   }

这可能是重复的,因为当我截获消息时,我会有类型为
org.springframework.http.client.interceptingclienthttpprequest
和`org.springframework.http.client.SimpleClientHttpResponse`的java对象。我需要的是响应的文本/xml表示形式,并记录此响应。您是否尝试将Apache httpClient传递给restTempalte并启用httpClient级别的日志?请阅读以下内容中的答案:[如何通过RestTemplate记录请求和响应rest调用]()请阅读我对以下问题的回答:只需将
@组件添加到自定义
拦截器
,就足够了吗?或者我必须在某个地方显式地注册它,例如在
restemplate
上?因为这正是我试图阻止的:必须自己注册并连接它。我相信@Component就足够了。您可以按照下面的链接,这是一个很好的例子来源。这会正确地记录日志,但是如果底层的
InputStream
不支持标记怎么办?一旦它被读取,它就消失了。我使用它时会出现一个错误,跟踪响应会阻止它稍后被编组到我的POJO中。不知道为什么,但它仍然有助于调试。