Spring Boot 使用ResponseBodyAdvice 打印 Controller 返回的body数据

背景是获取Controller类输出的结果数据。

实现方案,使用@RestControllerAdvice+ResponseBodyAdvice接口。不能使用Interceptor,在执行Interceptor时,response已经提交。也可以考虑aspect方案,不过实现麻烦些,增加较多的代码,效率低。

@Slf4j
@RestControllerAdvice
public class GlobalExceptionAndAdviceHandler implements ResponseBodyAdvice<Payload> {

    @ResponseStatus(HttpStatus.OK)
    @ExceptionHandler(RuntimeException.class)
    public Payload handleRuntimeException(RuntimeException ex) {
        log.error(ex.getMessage(), ex);
        return Payload.fail(HttpStatus.INTERNAL_SERVER_ERROR.value(), ex.getMessage(), null);
    }

    @Override
    public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) {
        /*判断方法参数是否为Payload*/
        return returnType.getParameterType().isAssignableFrom(Payload.class);
    }

    @Override
    public Payload beforeBodyWrite(Payload body, MethodParameter returnType, MediaType selectedContentType,
                                   Class<? extends HttpMessageConverter<?>> selectedConverterType,
                                   ServerHttpRequest request, ServerHttpResponse response) {
        /*日志输出body*/
        log.info("request.url={},response.data: {}",request.getURI().getPath(), JSON.toJSONString(body));
        return body;
    }
  • Payload 类为Controller统一返回的参数
  • 如果发生异常先执行handleRuntimeException再执行beforeBodyWrite

输出效果:

2024-04-17 17:35:00,925 INFO [http-nio-8080-exec-4] [00e8204cc30b4eb492185d410184745b] c.q.g.GlobalExceptionAndAdviceHandler request.url=/test/cnt/getReferenceAudio,response.data: {"code":500,"msg":"计算参考音频失败"}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冲上云霄的Jayden

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值