dubbo 序列化 问题 属性值 丢失 ArrayList 解决
参考文章:http://blog.csdn.net/wanyanxgf/article/details/6944733
http://tianya23.blog.51cto.com/1081650/582256/
这里重点说下解决办法:
由于dubbo采用的序列化和反序列化方案为hessian,但是 hessian 对ArrayList 采用CollectionSerializer类进行 序列化处理,这里 实际代码只会对 ArrayList第一层属性进行处理。
项目中使用PageList 封装类 继承了 ArrayList,并且里面有负责 java对象 PageTools,故 无法转换,属性丢失。
public class PageList<E> extends ArrayList<E> {
private static final long serialVersionUID = 6110720806295292900L;
private PagingTools pagingTools;
public PageList() {
this.pagingTools = new PagingTools();
}
public PageList(Collection<E> c) {
this(c, (PagingTools)null);
}
public PageList(Collection<E> c, PagingTools pageTools) {
super(c);
this.pagingTools = pageTools == null?new PagingTools():pageTools;
}
public PagingTools getPageTools() {
return this.pagingTools;
}
public void setPageTools(PagingTools pageTools) {
if(pageTools != null) {
this.pagingTools = pageTools;
}
}
}
解决方法: 使用其他 序列化方案 ,这里试了 json ,结果一样。 最终没办法,使用了java原生的序列化。
具体操作: 在 dubbo服务端和客户端 配置 序列化方案
<dubbo:protocol serialization="java"/>
h1. 现象
为一个dubbbo接口新增了一个方法:
- {code}
- DomainObject<String> testSer();
- 实现:
- @Override
- public DomainObject<String> testSer() {
- DomainObject<String> result = new DomainObject<String>();
- result.setAge(10);
- result.setName("test");
- result.add("DomainObject1");
- return result;
- }
- {code}
返回值定义如下:
- {code}
- public class DomainObject<E> extends ArrayList<E> {
- private static final long serialVersionUID = -7393642276493435828L;
- private String name;
- private int age;
- }
- {code}
远程调用:
- {code}
- DomainObject<String> result = voucherInfoQueryService.testSer();
- System.out.println(result.getAge());
- System.out.println(result.getName());
- System.out.println(result.get(0));
- {code}
输出结果:丢失了age和name两个属性的值,而 list内部的值还是存在的
- {code}
- 0
- null
- DomainObject1
- {code}
h1. 问题排查
h4. 使用java自带序列化执行序列化和反序列化, 不会出现属性丢失的问题,怀疑dubbo序列化有特殊处理
h4. dubbo 默认用的序列化协议是hessian2,查看代码
序列化时代码如下:
- {code}
- public void writeObject(Object object)
- throws IOException
- {
- if (object == null) {
- writeNull();
- return;
- }
- Serializer serializer;
- ##查找对应的serializer
- serializer = findSerializerFactory().getSerializer(object.getClass());
- ##序列化
- serializer.writeObject(object, this);
- }
- {code}
查找serializer:由代码可知,上面的DomainObject对应的serializer是CollectionSerializer
- {code}
- public Serializer getSerializer(Class cl)
- throws HessianProtocolException
- {
- ...
- else if (Collection.class.isAssignableFrom(cl)) {
- if (_collectionSerializer == null) {
- _collectionSerializer = new CollectionSerializer();
- ...
- }
- {code}
CollectionSerializer.writeObject
- {code}
- public void writeObject(Object obj, AbstractHessianOutput out)
- throws IOException
- {
- ...
- Iterator iter = list.iterator();
- while (iter.hasNext()) {
- Object value = iter.next();
- out.writeObject(value);
- }
- ...
- }
- {code}
所以,属性丢失。
dubbo 序列化 问题 属性值 丢失 ArrayList 解决的更多相关文章
- 浏览器后退按钮导致jquery动态添加的select option值丢失的解决方法
监控浏览器返回功能 判断浏览器返回功能 禁用浏览器的后退按钮 JS禁止浏览器后退键 http://volunteer521.iteye.com/blog/830522/ 浏览器返回功能 判断上一页面来 ...
- dubbo序列化hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决
dubbo序列化,hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决 转载声明: ...
- List<Object>中,以Object的某一属性值为参照进行排序,选取最大记录的解决办法
一.场景:java web, 在一列表中选取一条记录,该记录的某一个属性值在此List中为最大值: List的格式为List<Object>,其中Object为定义的Vo或者Po类,其中包 ...
- js获取元素属性值为空的原因和解决办法
问题描述:js获取某元素的属性值为空 代码: <!-- css定义在head中 --> <style> #box{ width: 100px; height: 100px; b ...
- JSP出现"属性值[request.getParameter("myMessage")]引用["],在值内使用时必须被转义"的解决方法
写JSP时出现属性值[request.getParameter("myMessage")]引用["],在值内使用时必须被转义. 源代码: <jsp:setPrope ...
- java对象json序列化时忽略值为null的属性
环境: jdk: openjdk11 操作系统: windows 10教育版1903 目的: 如题,当一个对象里有些属性值为null 的不想参与json序列化时,可以添加如下注解 import com ...
- VUE项目中使用this.$forceUpdate();解决页面v-for中修改item属性值后页面v-if不改变的问题
VUE项目中使用this.$forceUpdate();解决页面v-for中修改item属性值后页面v-if不改变的问题:https://blog.csdn.net/jerrica/article/d ...
- 解决引用类型为什么打出的是地址值,又怎么改成输出属性值(toString()底层)
一丶toString的源码解析: 一丶object的toString的源码解析: 集合中toString源码分析: 小结: 改成输出属性值 在父类中重写toString();方法 快捷键:Alt+In ...
- dubbo序列化的一点注意
最近工作中遇见了一个小问题,在此记录一下,大致是这样的,有一父类,有一个属性traceId,主要是记录日志号,这样可以把所有日志串起来,利于排查问题,所有的pojo对象继承于此,但是其中一同事在子类p ...
随机推荐
- html中的标签分类
单标签 <br> <hr> <img> <input> <param> <meta> <link> 双标签 < ...
- Linux命令-网络命令:traceroute
首先需要设置VM里面的linux系统能够上网.菜单项->虚拟机->设置,选择NAT模式 菜单项->编辑->虚拟网络编辑器->VMnet8 NAT模式->NAT设置, ...
- Docker 私有仓库最简便的搭建方法
http://blog.csdn.net/wangtaoking1/article/details/44180901/ Docker学习笔记 — Docker私有仓库搭建http://www.jian ...
- AssionShop开源B2C电子商务系统-概述(转载)
今天是个特殊的日子,我在北京房租价格又上了一个新的台阶.在这个日子我准备开始建立一个开源项目,一个B2C行业的EC系统. 一.关于定位 我要做的不只是一个商城,应该说是一个能满足中小型企业建立电子商务 ...
- DataProtectionConfigurationProvider加密web.config文件
web.config 文件中经常会包含一些敏感信息,最常见的就是数据库连接字符串了,为了防止该信息泄漏,最好是将相关内容加密. Aspnet_regiis.exe命令已经提供了加密配置文件的方法,系统 ...
- keystone WSGI流程
作为OpenStack两种基本的通信方式(RESTful API与消息总线)之中的一个.理解RESTful API的设计思路和运行过程,有助于我们对OpenStack有更好的理解.RESTful仅仅是 ...
- unity Editor下自启动
[InitializeOnLoad] 加上这个特性,并且在静态构造函数里写上内容.即可在Unity启动的时候自启动这个Editor脚本
- Atitit.request http乱码的设计防止 检测与解决最近实践p825 attilax总结.doc
Atitit.request http乱码的设计防止 检测与解决最近实践p825 attilax总结.doc 1 浏览器判断一个页面的编码有俩个途径, 一种是通过HTTP响应头, 一个是通过meta: ...
- Unity中使用ulua的个人经验总结
热度 286052 2015-3-15 14:32 |个人分类:技术类| Lua Lua代码都是运行时才编译的,不运行的时候就如同一张图片.一段音频一样,都是文件:所以更新逻辑只需要更新脚本,不需要再 ...
- 写一个简单的form表单,当光标离开表单的时候表单的值发送给后台
<body> <form action="index.php"> <input type="text" name="tx ...