gpt4 book ai didi

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

转载 作者:IT老高 更新时间:2023-10-28 13:50:41 25 4
gpt4 key购买 nike

我正在使用 springRestTemplate 来执行 GET 查询。

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

最佳答案

您可以通过在 Spring 中使用 ClientHttpRequestInterceptor 来实现。您必须重写接口(interface) 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;
}
}

关于java - 如何使用 spring 记录 RestTemplate 请求和响应?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31474006/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com