
SpringBoot 请求参数打印问题及解决方法
在 SpringBoot 应用中,调试时打印请求参数是常见需求。然而,直接使用 request.getParameterMap() 方法打印结果时,经常会遇到打印出内存地址而不是参数值的情况,或者 HTTP 头信息缺失。
问题分析:
-
内存地址输出:
request.getParameterMap()返回的是一个Map,键是参数名,值是参数值的字符串数组。log.info()直接打印数组对象时,输出的是其内存地址。 -
HTTP 头信息缺失:
request.getParameterMap()只获取请求体(body)中的参数,HTTP 头信息无法通过此方法获取。
解决方案:
为了正确打印请求参数及其值,需要将参数值数组转换为字符串:
MapparameterMap = request.getParameterMap(); parameterMap.forEach((key, value) -> log.info("参数名: {}, 参数值: {}", key, Arrays.toString(value)));
这段代码迭代 parameterMap,使用 Arrays.toString() 将参数值数组转换为易于阅读的字符串格式。
如果需要打印 HTTP 头信息,请使用 request.getHeader(headerName) 方法,其中 headerName 是要获取的头信息名称。例如:
String userAgent = request.getHeader("User-Agent");
log.info("User-Agent: {}", userAgent);
通过以上方法,即可在 SpringBoot 应用中正确打印请求参数和 HTTP 头信息,方便调试和日志记录。











