调用dubbo接口传入空参数报错

最近在新的项目中使用dubbo,很奇怪的是平时往接口里传入null都没问题,但是在该项目中却总是报错:

Failed to invoke the method test in the service.....
Fail to decode request due to: RpcInvocation....

上网查询一番之后发现了问题,是由于在dubbo-provider中使用了kryo序列化造成:
1093758-20171212113631566-338695375.jpg
第一次使用这个序列化工具,它比dubbo默认的hession2序列化快很多倍。
那么问题来了。究竟是为什么当参数传入null的时候会报错呢?

当provider指定序列化为 kryo 之后,dubbo在进行编码的时候和使用默认序列化方式是不一样的,看下面这段代码(DubboCodec.class):
1093758-20171212140534144-1662502472.png
当中框出的地方表明了如果序列化对象是 OptimizedSerialization 的时候还会调用 containComplexArguments方法判断实际传入的参数有多少个:
1093758-20171212140902832-338709485.png
这段代码说明了,一旦出现了值为 null 的参数,那么就会返回,然后写入参数数量为-1。
之后再来看解码端com.alibaba.dubbo.rpc.protocol.dubbo.DecodeableRpcInvocation 的 decode 方法:
1093758-20171212141403707-1679911247.png
参数为-1,那么就跳过了这一段,因此 args 和 pts 都是null,没有被初始化。同时,查看后续 in.readObject(Map.class) 方法,发现
com.esotericsoftware.kryo.Kryo 的 readClassAndObject 方法:
1093758-20171212142339504-1763246853.png
如果参数为空,registration.getSerializer() 获取的是 StringSerializer, 而参数齐全的时候获取的是 MapSerializer,在后续的操作中,StringSerializer 返回的是字符串,无法强转为 Map,因此会报错。
这样,终于搞明白了报错原因,但是问题是为什么要设计成这样?还是说是个BUG呢?

转载于:https://www.cnblogs.com/cbzj/p/8027609.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值