[英]PBKDF2 algorithm for both Java and PHP
我有一个网站。 本网站使用 PBKDF2 进行用户密码加密。 我必须用Java编写登录代码。 我在 google 上搜索了 Java 的 PBKDF2 算法。 但是,Java 和 PHP 的结果不同。
Java代码是
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.PBEKeySpec;
import java.util.Base64;
public class Hash {
public static void main(String[] args) throws Exception {
var password = "test".toCharArray();
var salt = Base64.getDecoder().decode("JvCjRQb/9X8rticKJrDP1uvBCDTz2WEF");
var iterationCount = 12000;
var keyLength = 24 * 8;
System.out.println(Base64.getEncoder().encodeToString(SecretKeyFactory.getInstance("PBKDF2WithHmacSHA256")
.generateSecret(new PBEKeySpec(password, salt, iterationCount, keyLength))
.getEncoded()));
}
}
结果:dvxvBMpmR6i4D9f1orGx9zUjH9cyv0sM(BellSoft Java 13)
PHP代码是
<?php
$algo = "sha256";
$password = "test";
$salt = "JvCjRQb/9X8rticKJrDP1uvBCDTz2WEF";
$count = 12000;
$key_length = 24;
echo base64_encode(hash_pbkdf2($algo, $password, $salt, $count, $key_length, true));
?>
结果:n7znKl8FBPH4ZPbZxPRHPf7vkey+5R2Y (PHP v7.2.24)
我无法编辑 PHP 代码,因为它是框架代码。 因此,我需要更改 Java 代码以匹配 PHP 结果。 如何更改我的 Java 代码?
function derivateKey($password, $salt, $iterations, $keyLengthBits)
{
return base64_encode(hash_pbkdf2(
'sha256',
$password,
base64_decode($salt),
$iterations,
$keyLengthBits/8,
true
));
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.