fix: 修复网关日志请求类型为application/json不打印查询参数问题

This commit is contained in:
郝先瑞 2022-05-05 19:20:41 +08:00
parent 3e23004c71
commit 6d3028b6f6
2 changed files with 22 additions and 5 deletions

View File

@ -87,7 +87,7 @@ public class LogFilter implements GlobalFilter, Ordered {
sb.append(entry.getKey()).append("=").append(val).append("&");
}
if (sb.length() > 0) {
traceLog.setRequestBody(sb.substring(0, sb.length() - 1));
traceLog.setQueryParams(sb.substring(0, sb.length() - 1));
}
log.info(traceLog.toRequestString());
ServerHttpResponseDecorator serverHttpResponseDecorator = serverHttpResponseDecorator(exchange, traceLog);
@ -110,11 +110,21 @@ public class LogFilter implements GlobalFilter, Ordered {
ServerRequest serverRequest = ServerRequest.create(exchange, messageReaders);
MultiValueMap<String, String> queryParams = exchange.getRequest().getQueryParams();
StringBuilder sb = new StringBuilder();
for (Map.Entry<String, List<String>> entry : queryParams.entrySet()) {
String val = entry.getValue().stream().map(String::valueOf).collect(Collectors.joining(","));
sb.append(entry.getKey()).append("=").append(val).append("&");
}
if (sb.length() > 0) {
traceLog.setQueryParams(sb.substring(0, sb.length() - 1));
}
Mono<String> cachedBody = serverRequest.bodyToMono(String.class).flatMap(body -> {
traceLog.setRequestBody(body);
log.info(traceLog.toRequestString());
return Mono.just(body);
});
}).doFinally(body -> log.info(traceLog.toRequestString()));
BodyInserter bodyInserter = BodyInserters.fromPublisher(cachedBody, String.class);
HttpHeaders headers = new HttpHeaders();

View File

@ -22,7 +22,13 @@ public class TraceLog {
private String requestMethod;
/**
* 请求实体
* 查询参数
*/
private String queryParams;
/**
* 请求体参数
*/
private String requestBody;
@ -50,7 +56,8 @@ public class TraceLog {
public String toRequestString() {
return
"^^^^^^^^请求日志^^^^^^^^: " + requestMethod + ':' + requestPath + '\n' +
"请求参数:" + requestBody + '\n' +
"查询参数:" + queryParams + '\n' +
"请求载荷:" + requestBody + '\n' +
"请求时间:" + requestTime;
}