使用字符数组保存密码, 比使用String保存密码更好

在Java 中, 使用字符数组保存密码 比使用String保存密码更好.

两点理由 :

  1. 很难从内存中清除.
    String 属于不可变对象, 他会被放到串缓冲池中以方便重复使用,所以它就可能在内存中被保留很长时间.
    这时任何能够访问内存的人, 都可以很容易看到明文密码
    当然, 根本就不应该使用明文密码
  2. Java 提供 JPasswordField组件的getPassword()方法
    这是特意为密码准备的, 不用吗? 不要偷懒
  3. 在你不知道的时刻, 可能被泄露到其他地方
    比如日志中. 2018年5月 twitter 数亿用户明文密码泄露(参见这里: 3.3亿用户密码疑泄露,Twitter出现重大安全漏洞 ), 就是一个例子
posted @ 2018-08-15 19:07  Hi_埃里克  阅读(440)  评论(0编辑  收藏  举报