当前位置: 首页 > article >正文

如何防止序列化破坏单例模式

    反射和序列化都可以破解懒汉式和饿汉式。下面来讨论一下如何防止序列化来破坏单例模式,

反序列化时会调用readObject方法,里面会判断是否有重写readResolve方法,如果重写了就会执行readResolve方法,并将方法的返回值返回,我们可以利用这一点,在单例模式的类中实现readResolve方法,将单例对象返回回来,这样序列化就不能破坏单例了。

代码如下:

package com.example.demo.entity;

import java.io.*;

public class Singleton implements Serializable{
    private static Singleton singleTon = new Singleton();

    private Singleton(){
    }

    public static Singleton getInstance(){
        return singleTon;
    }

    private Object readResolve(){
        return Singleton.singleTon;
    }


    public static void main(String[] args) throws Exception {
        Singleton instance = Singleton.getInstance();

        //把对象写入文件
        File file = new File(
                "a.txt");
        FileOutputStream fos = new FileOutputStream(file);
        ObjectOutputStream oos = new ObjectOutputStream(fos);
        oos.writeObject(instance);
        oos.close();
        fos.close();

        //序列化把对象读取
        FileInputStream fis = new FileInputStream(file);
        ObjectInputStream ois = new ObjectInputStream(fis);
        Singleton serilizeInstance = (Singleton) ois.readObject();

        System.out.println(instance == serilizeInstance);
    }
}


http://www.kler.cn/a/410473.html

相关文章:

  • 在win10环境部署opengauss数据库(包含各种可能遇到的问题解决)
  • C++:当vector中存储的是自定义类型对象时注意事项
  • PGSQL物化视图(Materialized View)
  • ODBC连接PostgreSQL数据库后,网卡DOWN后,客户端进程阻塞问题解决方法
  • ROS2 报错记录
  • C++中定义类型名的方法
  • 探索C/C++的奥秘之stack和queue
  • Python 数据分析核心库大全!
  • 《Python游戏编程入门》注-第8章5
  • go语言range的高级用法-使用range来接收通道里面的数据
  • spark 3.4.4 利用Spark ML中的交叉验证、管道流实现鸢尾花分类预测案例选取最优模型
  • 【zookeeper03】消息队列与微服务之zookeeper集群部署
  • 网络新技术新应用在网络安全领域的发展特点
  • 【GL004】Linux
  • vue3 reactive响应式实现源码
  • CTO 实际上是做什么的?
  • IP Transit國外頻寬使用最高優先權,國內直接與骨幹互連
  • archlinux 触摸板手势配置
  • crmeb 分享商品 邀请码 bug 修复 记录
  • java学习记录12
  • Ubuntu24虚拟机-gnome-boxes
  • PPT分享 | IBM集团业务流程架构顶层规划-订单到交付-销售到回款方案
  • 【强化学习的数学原理】第02课-贝尔曼公式-笔记
  • 大数据新视界 -- Hive 数据仓库:构建高效数据存储的基石(下)(2/ 30)
  • 卷积神经网络各层介绍
  • Long类型实体对象返给前端精度丢失问题