我们的基于Web的应用程序使用帐户创建期间指定的密码将用户帐户绑定到用户.对于
Java,在将哈希值保存在数据库中之前,如何安全地处理密码.
更具体地说,如何确保持有密码的字符串在足够短的时间间隔内被垃圾收集?
解决方法
如果您有可能(在Web应用程序中可能很难),最好将密码存储在字符数组中,而不是将它们存储在字符串中.如果您已完成存储密码,则可以使用
Array.fill()将其覆盖在内存中,并通过丢弃它来为垃圾收集器提供引用:
Arrays.fill(password,' '); password = null;
我只是注意到取消密码会有点偏执,但如果它让你放心,你可以做:)
原文地址:https://www.jb51.cc/java/128240.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。