doudi1449 2019-05-20 17:50
浏览 128
已采纳

php openssl_pbkdf2相当于java

I have some php code to encrypt a message to webservice. Now, I want to create the equivalent java code but get stuck. Please help

--PHP Code looks like

$length = 60;
$salt =  "MySalt";
$interation = 3000;
$bytes = openssl_pbkdf2("mypasspharse", $salt, $length, $interation, "sha1");

$value1 = substr($bytes, 0, 10);
$value2 = substr($bytes, 10, 20);
$value3 = substr($bytes, 30, 30);

return array('value1' => $value1, 'value2' => $value2, 'value3' => $value3);

--

I am trying to do the same thing in java using SecretKeyFactory. My java code looks like:

SecretKeyFactory factory = SecretKeyFactory
                .getInstance("PBKDF2WithHmacSHA1");
        PBEKeySpec spec = new PBEKeySpec(passphrase.toCharArray(),
                salt.getBytes("UTF-8"), interation, length);

Now I don't know how could I get the equivalent $value1, $value2, $value3 as php code. Also, Im not sure that I am doing the correct way to write the equivalent java code with the php code above. Any idea is very appreciated.

Thank you,

  • 写回答

1条回答 默认 最新

  • douliao5550 2019-05-20 19:47
    关注

    2 below examples produces the same output:

    PHP:

    $length = 60;
    $salt =  "MySalt";
    $interation = 10;
    $bytes = openssl_pbkdf2("mypasspharse", $salt, $length, $interation, "sha1");
    
    for ($i = 0; $i < 60; $i++)
    {
        echo dechex(ord($bytes[$i]));
        echo '<br>';
    }
    

    Java:

    int length = 60 * 8;
    String passphrase = "mypasspharse";
    String salt = "MySalt";
    int iteration = 10;
    
    SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA1");
    PBEKeySpec spec = new PBEKeySpec(passphrase.toCharArray(), salt.getBytes("UTF-8"), iteration, length);
    
    byte[] bytes = factory.generateSecret(spec).getEncoded();
    for (int i = 0; i < 60; i++) {
        System.out.println(Integer.toHexString(bytes[i] & 0xFF));
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧