zoukankan      html  css  js  c++  java
  • 一个netty序列化引起的思考。

    今天在使用netty 传输网络对象报了异常错误 java.io.InvalidClassException: failed to read class descriptor

    自己捣鼓了许久。

    后来查了下api InvalidClassException

    api文档描述:

    当 Serialization 运行时检测到某个类具有以下问题之一时,抛出此异常。

    • 该类的序列版本号与从流中读取的类描述符的版本号不匹配
    • 该类包含未知数据类型
    • 该类没有可访问的无参数构造方法

    然后看了下netty client和netty server bean 信息

    client 代码

    public class Document implements Serializable   {
    private static final long serialVersionUID = 8213761673743652497L;

    。。。。。。。。。。。。
    }

    Server bean 代码

    public class Document implements Serializable   {
    private static final long serialVersionUID = 1876613896675121682L;
    。。。。。。。。。。。。
    }

    仔细看下 不难发现 2个 bean的 serialVersionUID 不一致

    然后google一下 序列化ID(serialVersionUID)

    下面对序列化ID 的介绍

    简单来说,Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。

    当实现java.io.Serializable接口的实体(类)没有显式地定义一个名为serialVersionUID,类型为long的变量时,Java序列化机制会根据编译的class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,只有同一次编译生成的class才会生成相同的serialVersionUID 。

    如果我们不希望通过编译来强制划分软件版本,即实现序列化接口的实体能够兼容先前版本,未作更改的类,就需要显式地定义一个名为serialVersionUID,类型为long的变量,不修改这个变量值的序列化实体都可以相互进行串行化和反串行化。

    顿时幡然大悟,应该是serialVersionUID 不一致而且又不是同一次编译生成的class 。从而导致server端反序列化失败。

    于是想到了解决办法。让netty client 和 netty Server 共享一个Document 对象即解决了问题。



  • 相关阅读:
    大话设计模式C++实现-第1章-简单工厂模式
    mac下的git的安装与简单的配置
    Execute failed: java.io.IOException: Cannot run program "sdk-linux/build-tools/22.0.0/aapt": error=2
    UIScrollView 循环滚动,代码超简单
    字符编码的前世今生
    Android 4.4 KitKat 支持 u 盘功能
    Java Tread多线程(1)实现Runnable接口
    (hdu step 6.3.3)Air Raid(最小路径覆盖:求用最少边把全部的顶点都覆盖)
    每日算法之二十三:Reverse Nodes in k-Group
    Android4.0-4.4 加入实体按键振动支持的方法(java + smali版本号)
  • 原文地址:https://www.cnblogs.com/montya/p/2378773.html
Copyright © 2011-2022 走看看