首页 > 文章列表 > SpringBoot请求参数打印异常:为什么打印的是内存地址而不是参数值?

SpringBoot请求参数打印异常:为什么打印的是内存地址而不是参数值?

328 2025-03-21

SpringBoot请求参数打印异常:为什么打印的是内存地址而不是参数值?

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 头信息,方便调试和日志记录。

来源:1740145779