让Singleton模式的类防止攻击

早些时候的Singleton模式如下:

 

老版的单例模式,存在的第一个问题,一个有权限的客户端可以使用反射机制,调用私有构造方法,就可以构建多个实例,这是不希望看到的。所以为了防止反射攻击,必须在构造方法上检查创建第二个实例时,抛出异常。

存在的第二个问题不多见,假如,一个单例的类,需要被实例化,简单的一个实现 Serializable 接口是不够的。

为了保证类是单例的,该类的实例必须是瞬时的(transient),并且提供一个 readResolve方法,否则反序例化时,会异致第二个类实例的产生。


自JDK1.5发行版开始,我们还有一种方式构建Singleton,将更加安全,而且是可序列化的,绝对的单例。

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值