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

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

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

代码如下:

java 复制代码
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);
    }
}
相关推荐
大数据新鸟19 小时前
单例模式的变种
单例模式
yaaakaaang19 小时前
一、单例模式
单例模式
Yupureki1 天前
《Linux系统编程》20.常见程序设计模式
linux·服务器·c语言·c++·单例模式·建造者模式·责任链模式
pedestrian_h2 天前
Java单例模式回顾
java·单例模式·设计模式
苏渡苇2 天前
枚举的高级用法——用枚举实现策略模式和状态机
java·单例模式·策略模式·枚举·状态机·enum
·心猿意码·4 天前
C++ 线程安全单例模式的底层源码级解析
c++·单例模式
南境十里·墨染春水4 天前
C++传记 详解单例模式(面向对象)
开发语言·c++·单例模式
无籽西瓜a5 天前
【西瓜带你学设计模式 | 第一期-单例模式】单例模式——定义、实现方式、优缺点与适用场景以及注意事项
java·后端·单例模式·设计模式
格图素书6 天前
大数据在电力行业的应用案例解析-【电力技术】(零)大数据在电力行业的典型落地案例(序)
大数据·单例模式
chushiyunen7 天前
python单例模式、大模型一次加载多次复用
开发语言·python·单例模式