在PHP

时间:2016-06-18 17:05:31

标签: java php hash sha256

我的系统上的用户在Java应用程序(来源:https://github.com/madtomic/LogIt-1/tree/master/src/main/java/io/github/lucaseasedup/logit/security)中注册,并使用SHA-256和salt进行散列密码。我现在想要在我的WWW页面上添加登录系统。但是我无法验证密码。

示例用户:

  • 密码:test
  • 盐:oqhyqTbtEXYYRf8r9jJn
  • 来自JAVA的哈希: adf6a822c860ad7dc39eb035be1e362ad72f4535eed9a41dc8f99a122d78f5ef

PHP测试代码:

$_POST['salt'] = "oqhyqTbtEXYYRf8r9jJn";
$_POST['hash'] = "adf6a822c860ad7dc39eb035be1e362ad72f4535eed9a41dc8f99a122d78f5ef";
$_POST['pass'] = "test";


echo("<br>HASH_HMAC ".hash_hmac("sha256", $_POST['pass'], $_POST['salt']));

echo("<br>HASH ".hash("sha256", $_POST['salt']. $_POST['pass']));

echo("<br> HASH #2 ". hash('sha256', $_POST['salt'] . hash('sha256', $_POST['pass']) ));

echo('<br>Java hash: ' . $_POST['hash']);

结果:

  • HASH_HMAC cc3dcc320479034414506c4ad44fda205b4f5687ff988fa4316edb94d05364ff
  • HASH b7d8154812a95e0fad70533feb8b1c8b3a53e9efcff936eb5c308d481b6594e6
  • HASH#2 183d017d9169efbfd5f62ddfacd8d6ef631be287f17e9767fe3978bbc366444c
  • Java哈希:adf6a822c860ad7dc39eb035be1e362ad72f4535eed9a41dc8f99a122d78f5ef

来自PHP的任何东西都与Java哈希匹配:(我该怎么办?

1 个答案:

答案 0 :(得分:1)

我认为您可以使用PHP hash函数并将您的salt与密码连接。

$salt = 'oqhyqTbtEXYYRf8r9jJn';
$pass = 'test';
echo hash('sha256', $pass . $salt);

输出:

  

adf6a822c860ad7dc39eb035be1e362ad72f4535eed9a41dc8f99a122d78f5ef

演示:https://eval.in/591374