org.springframework.web.util.NestedServletException: Hessian skeleton invocation failed; nested exception is com.caucho.hessian.io.HessianProtocolException:
.......
Caused by: com.caucho.hessian.io.HessianProtocolException: getList: expected end of call ('xxx') at 0x53 (S). ..... com.caucho.hessian.client.HessianRuntimeException: com.caucho.hessian.io.HessianProtocolException:
.......
排查过程: Caused by: com.caucho.hessian.io.HessianProtocolException: getList: expected end of call ('xxx') at 0x53 (S). 根据以下报错可以看出是调用getList方法时报错,将server端提供的接口反编译发现,getList存在多个,也就是存在重载的情况。
问题原因: 查找相关资料发现,Hessian的HessianFactory的isOverloadEnabled属性默认为false。这个参数如果为false,Hessian调用的时候获取接口仅根据方法名;反之,Hessian调用时决定调用哪个方法是通过方法名和参数类型一起决定。所以也就解释了,存在重载的方法时为什么会报以上错误。
解决办法: 1.在初始化HessianFactory对象时写在构造函数里,对factory设置 setOverloadEnabled(true) ,问题解决。 2.服务端,方法名称修改下