绝对密位
2020-12-30 00:04
采纳率: 100%
浏览 13
已采纳

Java反序列化概率性出错怎么解决?

程序是TCP的网络通信工具

使用 ByteArrayOutputStream和ObjectOutputStream实现序列化对象 

在文件传输的时候会概率性反序列化出错

public class SerialUtils {
    public static byte[] serialObject(Object obj) throws SerialException {
        ByteArrayOutputStream bOut = null;
        ObjectOutputStream out = null;
        try {
            try {
                bOut = new ByteArrayOutputStream();
                out = new ObjectOutputStream(bOut);
                out.writeObject(obj);
                return bOut.toByteArray();
            } finally {
                if (out != null) {
                    out.close();
                }
                if (bOut != null) {
                    bOut.close();
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
            throw new SerialException(e);
        }
    }

    public static <T> T serialObject(byte[] data) throws SerialException {
        ByteArrayInputStream bIn = null;
        ObjectInputStream in = null;
        try {
            try {
                bIn = new ByteArrayInputStream(data);
                // 错误发生在这一行
                in = new ObjectInputStream(bIn);
                return (T) in.readObject();
            } catch (ClassNotFoundException e) {
                throw new SerialException("找不到实现反序列化的类", e);
            } finally {
                if (in != null) {
                    in.close();
                }
                if (bIn != null) {
                    bIn.close();
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
            throw new SerialException(e);
        }
    }
}

运行到 in = new ObjectInputStream(bIn); 这一行会概率性出错

java.io.StreamCorruptedException: invalid stream header: 37BB7395

冒号后面的数字完全随机

大概十次有四五次出错 具体概率完全看脸 跟抽卡似的

如果不是传文件就没有报过这类错误

数据校验完整 不存在数据损坏的问题 外面还有一层用于保证传输数据的完整性可靠

传文件我设置的单次发送大小为4M 我从4K该到8M都会有概率出现这个错误

大佬们帮忙看看咋处理

synchronized和去掉静态都没用

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • viewgroup 2020-12-30 10:21
    已采纳

    最简单的办法就是将类转为json,然后通过流将字符串发送过去,接收方接受json,转换为对应的对象就可以了

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • damoneric_guo 2020-12-30 08:50

    文件用FileOutputStream,其他的用ObjectOutputStream

    评论
    解决 无用
    打赏 举报
  • 绝对密位 2020-12-30 17:44

    jdk自身的序列化虽然好用 但是一个受到版本影响 查资料偶尔发现jdk7和8的序列化不通用

    另外就是程序更新代码之后 如果有非功能性的变动也会导致反序列化失败 所以准备弃用自身的序列化 换成fastjson 就是本来打完包是204k的程序(不用aspectj的话149k ) 加一个fastjson直接940k了。。。 心里总觉得不爽

    为了不引入spring那一堆(太大了)自己写的Ioc容器和AOP 后来引入了aspectj 基本放弃自己的AOP了 现在就差个自动注入 不过懒得实现了

    另外就是这个问题没找到原因 本地用没问题 一用到socket上就出问题 抓狂!!!

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题