微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 创建帐户时如何在内存中安全地存储密码?

我们的基于Web的应用程序使用帐户创建期间指定的密码将用户帐户绑定到用户.对于 Java,在将哈希值保存在数据库中之前,如何安全地处理密码.

更具体地说,如何确保持有密码的字符串在足够短的时间间隔内被垃圾收集?

解决方法

如果您有可能(在Web应用程序中可能很难),最好将密码存储在字符数组中,而不是将它们存储在字符串中.如果您已完成存储密码,则可以使用 Array.fill()将其覆盖在内存中,并通过丢弃它来为垃圾收集器提供引用:
Arrays.fill(password,' ');
password = null;

我只是注意到取消密码会有点偏执,但如果它让你放心,你可以做:)

原文地址:https://www.jb51.cc/java/128240.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐