我目前正在处理一小段代码,应该在将byte []存储到文件之前对其进行加密。在以下代码段中,我尝试使用PBKDF2从密码生成SecretKey。

public SecretKey deriveKey(String password)
        throws NoSuchAlgorithmException, InvalidKeySpecException {
    SecretKeyFactory kf = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA1");
    KeySpec specs = new PBEKeySpec(password.toCharArray());
    SecretKey key = kf.generateSecret(specs);
    return key;
}


这引发了异常


  java.security.spec.InvalidKeySpecException:找不到盐


在return语句之前的最后一行。这对我来说似乎很混乱,因为PBEKeySpec明确不需要任何其他参数,如here所示。

这不是悲剧,无论如何我以后都会加盐,甚至在上面已经定义好了,但是我很好奇是否有人知道为什么会这样。我可能正在做一些非常错误的事情,只是没有注意到。

最佳答案

与PBEKeySpec类是否需要盐无关。算法PBKDF2
需要盐。该API是一种通用api,应满足多种算法,其中某些算法可能会在将来定义。

10-01 22:58