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

Posted hi-eric

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用字符数组保存密码, 比使用String保存密码更好相关的知识,希望对你有一定的参考价值。

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

两点理由 :

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





以上是关于使用字符数组保存密码, 比使用String保存密码更好的主要内容,如果未能解决你的问题,请参考以下文章

UiPath中如何安全的保存账号密码

如何查看Chrome浏览器保存的账号密码?

Java 使用 char[] Array 还是 String 存储字符串密码

为什么存储密码字符数组比字符串更合适?

java标准-密码用数组比用字符串安全

如何检查用户名和密码是不是已保存在钥匙串中