2023-02-22
原文作者:键盘林 原文地址:https://blog.csdn.net/qq_37909508/category_8976362.html

通过反射来破坏单例模式

一定要记得将setAccessible()设置为true

202302222101484351.png

在私有构造方法中增加一层判断

202302222101507672.png

再一次运行:

由于反射创建对象,是通过构造函数来进行创建的,所以我们在私有构造方法中,增加一层判断就可以了。

202302222101522153.png

对于延迟加载的懒汉式

202302222101538234.png

202302222101556475.png

运行之后,和我们预期是一样的

202302222101575096.png

但是如何调换加载顺序呢?

让反射先执行,然后延迟创建对象后执行的话,结果就是两个不同的对象

202302222101585497.png

解决办法,添加一个信号变量

202302222101598418.png

运行程序

202302222102011759.png

这种方式很好的组织的反射的攻击,但是其实反射对于这种来说也是可以破坏的

通过new出来的对象,直接反射修改它的私有信号变量

2023022221020339510.png

运行结果 :

2023022221020528311.png

这就说明我们通过反射将flag这个信号变量设置成了true

2023022221020659312.png

了解反射的小伙伴应该是知道的,在java反射面前说有的属于都是可见的,可以被修改的。所以在java中反射一般是慎用的!

阅读全文