目前,我收到了以下java代码片段,作为如何根据提供的“in”和“salt”变量计算散列的示例。在这些示例中,对变量进行了硬编码以进行测试:
package generatehash;
import java.security.MessageDigest;
import sun.misc.BASE64Encoder;
public class GenerateHash {
public static void main(String[] args)
{
String in = "abcdef12345";
String salt = "test1";
try {
MessageDigest hash = MessageDigest.getInstance("SHA-256");
byte[] digest = hash.digest((in + salt).getBytes());
String out = new BASE64Encoder().encode(digest);
System.out.println("Calculated: " + out);
} catch(java.security.NoSuchAlgorithmException e) {
System.err.println("SHA-256 is not a valid message digest algorithm. " + e.toString());
}
}
}这里的输出是:
计算:bfiUcT46ftaC76MCbGbpCFisFSlEY 96/4 4CBwdtznaCE=
在尝试运行PHP等效程序时,我尝试了以下操作:
<?php
ini_set('display_errors','On');
error_reporting(E_ALL);
$in = 'abcdef12345';
$salt = 'test1';
$out = hash('sha256', $in.$salt);
echo 'Calculated: ' . $out;这里的输出完全不同:
计算: 6df894713e3a7ed682efa3026c66e90858ac15294463debfe0207076dce76821
我试过一些变体,但没有击中目标。这里有什么东西我遗漏了吗?任何帮助都将不胜感激。
发布于 2017-07-07 05:53:03
Java结果在base64中,而php结果在十六进制中。您忽略了base64编码原始结果的步骤。
$in = 'abcdef12345';
$salt = 'test1';
$out = hash('sha256', $in.$salt,true); //3rd parameter says return raw result
echo 'Calculated: ' . base64_encode($out);产出:
计算:bfiUcT46ftaC76MCbGbpCFisFSlEY 96/4 4CBwdtznaCE=
示例:http://sandbox.onlinephpfunctions.com/code/bb12ed98c16e2b732f29292da75aeebc36da2d48
https://stackoverflow.com/questions/44963287
复制相似问题