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

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

反序列化时会调用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);
    }
}
相关推荐
重生之我是Java开发战士8 天前
【Java SE】多线程(三):单例模式,阻塞队列,线程池与定时器
java·javascript·单例模式
许彰午9 天前
34_Java设计模式之单例模式
java·单例模式·设计模式
罗超驿11 天前
10.Java单例模式全解析:饿汉式与懒汉式实现及线程安全深度剖析
安全·单例模式·javaee
布朗克16811 天前
33 设计模式精讲
java·单例模式·设计模式
雨浓YN11 天前
基于设计模式的Winform软件框架-01Xml\Log\Ini日志(单例模式+生产者消费者模式)
单例模式·设计模式
仙俊红12 天前
Java 单例模式:类里面为什么可以有自己类型的字段?
java·开发语言·单例模式
swordbob12 天前
prototype 注入到 singleton 里,prototype是否还是线程安全的
安全·spring·单例模式·原型模式
谁似人间西林客14 天前
工业大数据实战:看中国智造如何用数据驱动效率革命
大数据·单例模式
张小姐的猫14 天前
【Linux】多线程 —— 线程池 | 单例模式 | 常见锁
linux·运维·服务器·c++·单例模式·设计模式·策略模式
Java面试题总结15 天前
双重检验锁的单例模式在高并发下的可见性问题
单例模式