参考文章: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接口新增了一个方法:

  1. {code}
  2. DomainObject<String> testSer();
  3. 实现:
  4. @Override
  5. public DomainObject<String> testSer() {
  6. DomainObject<String> result = new DomainObject<String>();
  7. result.setAge(10);
  8. result.setName("test");
  9. result.add("DomainObject1");
  10. return result;
  11. }
  12. {code}

返回值定义如下:

  1. {code}
  2. public class DomainObject<E> extends ArrayList<E> {
  3. private static final long serialVersionUID = -7393642276493435828L;
  4. private String name;
  5. private int    age;
  6. }
  7. {code}

远程调用:

  1. {code}
  2. DomainObject<String> result = voucherInfoQueryService.testSer();
  3. System.out.println(result.getAge());
  4. System.out.println(result.getName());
  5. System.out.println(result.get(0));
  6. {code}

输出结果:丢失了age和name两个属性的值,而 list内部的值还是存在的

  1. {code}
  2. 0
  3. null
  4. DomainObject1
  5. {code}

h1. 问题排查

h4. 使用java自带序列化执行序列化和反序列化, 不会出现属性丢失的问题,怀疑dubbo序列化有特殊处理

h4. dubbo 默认用的序列化协议是hessian2,查看代码

序列化时代码如下:

  1. {code}
  2. public void writeObject(Object object)
  3. throws IOException
  4. {
  5. if (object == null) {
  6. writeNull();
  7. return;
  8. }
  9. Serializer serializer;
  10. ##查找对应的serializer
  11. serializer = findSerializerFactory().getSerializer(object.getClass());
  12. ##序列化
  13. serializer.writeObject(object, this);
  14. }
  15. {code}

查找serializer:由代码可知,上面的DomainObject对应的serializer是CollectionSerializer

  1. {code}
  2. public Serializer getSerializer(Class cl)
  3. throws HessianProtocolException
  4. {
  5. ...
  6. else if (Collection.class.isAssignableFrom(cl)) {
  7. if (_collectionSerializer == null) {
  8. _collectionSerializer = new CollectionSerializer();
  9. ...
  10. }
  11. {code}

CollectionSerializer.writeObject

  1. {code}
  2. public void writeObject(Object obj, AbstractHessianOutput out)
  3. throws IOException
  4. {
  5. ...
  6. Iterator iter = list.iterator();
  7. while (iter.hasNext()) {
  8. Object value = iter.next();
  9. out.writeObject(value);
  10. }
  11. ...
  12. }
  13. {code}

所以,属性丢失。

dubbo 序列化 问题 属性值 丢失 ArrayList 解决的更多相关文章

  1. 浏览器后退按钮导致jquery动态添加的select option值丢失的解决方法

    监控浏览器返回功能 判断浏览器返回功能 禁用浏览器的后退按钮 JS禁止浏览器后退键 http://volunteer521.iteye.com/blog/830522/ 浏览器返回功能 判断上一页面来 ...

  2. dubbo序列化hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决

    dubbo序列化,hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决 转载声明: ...

  3. List<Object>中,以Object的某一属性值为参照进行排序,选取最大记录的解决办法

    一.场景:java web, 在一列表中选取一条记录,该记录的某一个属性值在此List中为最大值: List的格式为List<Object>,其中Object为定义的Vo或者Po类,其中包 ...

  4. js获取元素属性值为空的原因和解决办法

    问题描述:js获取某元素的属性值为空 代码: <!-- css定义在head中 --> <style> #box{ width: 100px; height: 100px; b ...

  5. JSP出现"属性值[request.getParameter("myMessage")]引用["],在值内使用时必须被转义"的解决方法

    写JSP时出现属性值[request.getParameter("myMessage")]引用["],在值内使用时必须被转义. 源代码: <jsp:setPrope ...

  6. java对象json序列化时忽略值为null的属性

    环境: jdk: openjdk11 操作系统: windows 10教育版1903 目的: 如题,当一个对象里有些属性值为null 的不想参与json序列化时,可以添加如下注解 import com ...

  7. VUE项目中使用this.$forceUpdate();解决页面v-for中修改item属性值后页面v-if不改变的问题

    VUE项目中使用this.$forceUpdate();解决页面v-for中修改item属性值后页面v-if不改变的问题:https://blog.csdn.net/jerrica/article/d ...

  8. 解决引用类型为什么打出的是地址值,又怎么改成输出属性值(toString()底层)

    一丶toString的源码解析: 一丶object的toString的源码解析: 集合中toString源码分析: 小结: 改成输出属性值 在父类中重写toString();方法 快捷键:Alt+In ...

  9. dubbo序列化的一点注意

    最近工作中遇见了一个小问题,在此记录一下,大致是这样的,有一父类,有一个属性traceId,主要是记录日志号,这样可以把所有日志串起来,利于排查问题,所有的pojo对象继承于此,但是其中一同事在子类p ...

随机推荐

  1. Xcode中利用git源代码版本号控制

    git是一个版本号控制系统,能够通过命令行来调用,也有专门的桌面软件.这里主要介绍在Xcode中怎样利用git来进行版本号的控制. 一.创建git源 从Xcode5開始引入了使用git的一些新特性.将 ...

  2. SICP 1.23-1.26体会

    1.23 代码修改非常easy, 关键是时间. 电脑上算了一下. 100000000下面全是0. 開始还以为代码写错了. 最后没办法, 用1e10 1e11来计算. 发现比 1e11 1e12快1.2 ...

  3. Zip 压缩问题件,获取真实扩展名

    ].InputStream); foreach (var element in _ZIP.Entries) { using (System.IO.StreamReader _ddd = new Sys ...

  4. UNIX网络编程卷1 时间获取程序client UDP 协议无关

    本文为senlie原创.转载请保留此地址:http://blog.csdn.net/zhengsenlie /** * UDP.协议无关,调用 getaddrinfo 和 udp_client **/ ...

  5. TomEE

    https://tomee.apache.org/ Apache TomEE, pronounced "Tommy", is an all-Apache Java EE 6 Web ...

  6. lua的时间和日期函数

    lua的时间和日期函数 -- ::| 分类: Lua | 标签:lua 时间 函数 |举报|字号 订阅 下载LOFTER客户端 --获取当前的时间戳,单位是秒. time=os.time(); pri ...

  7. java虚拟机的逃逸分析

    逃逸分析作为其他优化手段提供依据的分析技术,其基本行为就是分析对象动态作用域:当一个对象在方法中被定义后,它可能被外部方法所引用,例如作为调用参数传递到其他方法中,称为方法逃逸.甚至还有可能被外部线程 ...

  8. json-lib解析json之二维JSONArray

    在接口测试中,不管是接口的请求报文还是接口的响应报文,数据全部使用json,在工作中避免不了去解析响应报文以获取某个键的值,解析josn有两种方式,一种是利用jackson,还有一种就是利用json- ...

  9. (译)Getting Started——1.2.4 Tutorial:Storyboard(故事板)

    该教程是基于你在前面的课程中构建的项目上进行的.学完本教程后,你将使用你前面学到的视图.视图控制器.动作.导航的内容,还会为应用创建一些关键的用户界面,并在场景中添加行为 以下就是本节课的内容: 1. ...

  10. 换个角度剖析iptables防火墙

    这篇文章会尽量以通俗易懂的方式描述iptables的相关概念,请耐心的读完它. 防火墙相关概念 此处先描述一些相关概念. 从逻辑上讲.防火墙可以大体分为主机防火墙和网络防火墙. 主机防火墙:针对于单个 ...