java浅拷贝BeanUtils.copyProperties引发的RPC异常

💡 原文中文,约1200字,阅读约需3分钟。
📝

内容提要

作者吴义分享了一个项目中的bug排查经历,因测试延误遇到java.lang.ClassCastException异常。经过排查,发现问题源于BeanUtils.copyProperties的浅拷贝导致反序列化错误,最终通过手动赋值解决,并反思了使用BeanUtils的风险。

🎯

关键要点

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

继续阅读