SpringBoot 请求参数打印问题及解决方法
在 SpringBoot 应用中,调试时打印请求参数是常见需求。然而,直接使用 request.getParameterMap()
方法打印结果时,经常会遇到打印出内存地址而不是参数值的情况,或者 HTTP 头信息缺失。
问题分析:
内存地址输出: request.getParameterMap()
返回的是一个 Map
,键是参数名,值是参数值的字符串数组。 log.info()
直接打印数组对象时,输出的是其内存地址。
HTTP 头信息缺失: request.getParameterMap()
只获取请求体(body)中的参数,HTTP 头信息无法通过此方法获取。
解决方案:
为了正确打印请求参数及其值,需要将参数值数组转换为字符串:
Map parameterMap = 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 头信息,方便调试和日志记录。