繁体   English   中英

适用于 Java 和 PHP 的 PBKDF2 算法

[英]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
));
}

这里的原始想法https://stackoverflow.com/a/46430311/934967

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM