Spring的RequestBodyAdvice拦截小细节浅析

背景

因为项目接口需要进行解密,需要对数据进行统一处理,就使用了ReuqestBodyAdvice进行数据解密处理,但是偶然的发现supports方法会出现执行两次的情况,觉得有点奇异就进行了一次断点调试,然后就发现了执行两次的原因;

过程

1.默认supports方法返回false,表示不做任何处理:
不做处理
2.默认supports方法返回true,表示对数据进行处理:
处理数据
如图所示无论supports方法返回true还是false,只要这个ReuqestAdvice存在并且在spring中生效,supports方法都会执行两次;

了解了前置情况接下来就是用断点进行接口调试了:
第一次跳过supports方法后的跳转:
第一次执行完supports方法
第二次执行完supports方法之后的跳转:
第二次执行完supports方法之后的跳转
如图所示,如果有经常对看源码或者眼尖的朋友应该就会方法两次执行完supports方法之后跳转的方法名是有区别的:
第一次执行后跳转: beforeBodyRead
第二次执行后跳转: afterBodyRead

结论

如上述的调测结果所示,实现RequestBodyAdvice接口之后的拦截在成功执行的时候会调用两次supports方法.
而执行两次的原因是因为需要分别对beforeBodyRead和afterBodyRead进行判断:
当第一次supports方法返回结果是true的时候表示会执行beforeBodyRead方法
当第二次supports方法返回true的时候表示会执行afterBodyRead方法.
反之亦然
PS: 一个比较容易被人忽视但是找不到解决方法的小细节:
若是Controller类上的方法参数没有加上@RequestBody标签则该RequestBodyAdvice是不会被执行的.
如果上述内容存在问题,麻烦各位留言指出会第一时间修改.

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值