java浅拷贝BeanUtils.copyProperties引发的RPC异常
💡
原文中文,约1200字,阅读约需3分钟。
📝
内容提要
作者吴义分享了一个项目中的bug排查经历,因测试延误遇到java.lang.ClassCastException异常。经过排查,发现问题源于BeanUtils.copyProperties的浅拷贝导致反序列化错误,最终通过手动赋值解决,并反思了使用BeanUtils的风险。
🎯
关键要点
- 作者吴义分享了项目中的bug排查经历,遇到java.lang.ClassCastException异常。
- 测试时间因其他流程原因耽搁,导致排查时出现问题。
- 初步怀疑是传参的报文格式有问题,但通过测试工具验证后发现调用成功。
- 重点关注调用方的序列化方式和最近的代码改动,确认逻辑没有问题。
- 通过单测确认服务端收到的报文格式没有问题,开始排查代码。
- 发现问题源于BeanUtils.copyProperties的浅拷贝导致反序列化错误。
- 解决方案是去掉BeanUtils.copyProperties,进行手动赋值。
- 反思使用BeanUtils的风险,建议使用MapStruct进行转换。
➡️