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

AES 256Rijndael加密文本的BCrypt河豚密码

如何解决AES 256Rijndael加密文本的BCrypt河豚密码

| 我决定尝试使用BCrypt作为AES256(Rijndael / CBC)的哈希密钥。 问题是AES256密钥必须为32个字节长。 BCrypt密钥的长度为60个字节,并且自然总是不同的。也许要花很多辛苦和漫长的一周,但我无法看到如何将与BCrypt哈希在一起的密钥与AES256结合使用。我只是累了又瞎了吗,还是没有办法呢? 谢谢     

解决方法

        您是否在尝试对某些内容(例如密码)进行哈希处理并将其用作AES密钥? 我不熟悉BCrypt,但是SHA-256会创建与AES 256密钥大小相同的哈希。或者,如果您打算使用BCrypt,则可以只读取该哈希的前32个字节,而将其余的丢弃。     ,        我不认为您应该从加密计算中丢弃字节,因为这些字节应该支持您保留的其他字节-丢弃某些字节会削弱输出。     ,        您需要的是安全的密钥派生功能。有时可以按照注释中的建议截断字节,但是它始终取决于上下文,因此,如果您不确定,则不要这样做。 在需要“拉伸”输入的情况下,截断仍然无法工作,这也是最容易出错的地方。如果您无法使用安全的随机生成器来创建密钥,通常,您要做的就是将一些非随机输入(例如密码)转换为值得作为密钥材料的内容。显然,非随机数据的熵通常不足以达到目的。 如果要将密码转换为用于AES或任何其他对称加密算法的任意长度的密钥,请查看PKCS#5并使用其PBKDF2。     

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

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?