今天调试代码时, 调用本地 dubbo 服务, 发生异常, 日志如下
java.lang.ClassCastException: java.util.HashMap cannot be cast to xxx, dubbo version: 2.5.3, current host: xxx
参数传递的没有问题, 但是 dubbo 服务却收到的属性是 HashMap.
后来调试发现我们在 consumer 层使用 BeanUtils.copy
导致.
BeanUtils.copy
是浅拷贝, 如果该对象包含 List 集合属性, 那么只会赋值指针 , 而不是复制一份新的对象.
由于这两个 List 集合泛型不一致 , 虽然 copy 成功了, 但是目标类中的该 list 属性中的元素仍然是原来的数据, 并且仍然是原来的数据类型.
Dubbo Provider 收到后, 发现该类无法加载, 会自动降级转为 HashMap
对象 , 即 List<HashMap <String, Object>>
这种. 运行时, 我们遍历该集合就会发生异常
java.lang.ClassCastException: java.util.HashMap cannot be cast to xxx, dubbo version: 2.5.3, current host: xxx
解决: 这里不使用 BeanUtils.copy
.
曲线救国, 使用 Json 工具类转为字符串再解析为 java 对象的方式转换对象, 再传给 Dubbo 即可