这是C++代码:
#include <stdio.h>
#include <openssl/sha.h>
#include <string>
#include <gmp.h>
std::string base36enc(std::string data){
mpz_t nr;
mpz_init(nr);
mpz_set_str(nr, data.c_str(), 16);
return std::string(mpz_get_str(NULL, 36, nr));
}
//sha512 function here...
int main(){
std::string data = "deadbeef1234d0";
printf("Raw data to base36:\t%s\n",base36enc(data).c_str());
printf("SHA512 data to b36:\t%s\n",base36enc(sha512(data)).c_str());
printf("SHA512 data only :\t%s\n",sha512(data).c_str());
return 0;
}
输出是:
Raw data to base36: h55o0dxfmj4
SHA512 data to b36: clldzg9hyfl5ihp0taww8rny0jxvz67rsk1w4og26zqyt4hdrya68yme09iwtew0tdq6aro9rk3jy2m3r2zpegumccc8ssrbnfr
SHA512 data only : 4f3aff747e9ce090e5dfc5f23ce2a37233a21cfa2db7db70c984bc9ff8b263c9e02a6a485455c8042d10112f659a965e0bbf9645ee0c0e0c0824970dd879f667
这是PHP代码:
<?php
$data = "deadbeef1234d0";
echo "Raw data to base36: <b>".base_convert($data, 16, 36)."</b><br>";
echo "SHA512 data to b36: <b>".base_convert(hash(sha512,$data), 16, 36)."</b><br>";
echo "SHA512 data only : <b>".hash(sha512,$data)."</b>";
PHP的输出是:
Raw data to base36: h55o0dxfmj4
SHA512 data to b36: g8804wccs0kc8w8ckkogoc8ssgcs8ccc0sgssgs4g0gok8k8kkgss0og44swkwsc
SHA512 data only : 4f3aff747e9ce090e5dfc5f23ce2a37233a21cfa2db7db70c984bc9ff8b263c9e02a6a485455c8042d10112f659a965e0bbf9645ee0c0e0c0824970dd879f667
转换为 base36 的加密字符串在 PHP 和 C++ 中有所不同。但不是加密会导致问题(散列结果始终匹配)。如果将数据中的最后一个字符更改为 1 或任何高于 0 的十六进制数字,原始数据输出会有所不同,我不明白为什么!
例如,如果数据是“deadbeef1234d f ”,则 raw-data-to-base36 的 C++ 输出将为“h55o0dxfmj j ”,PHP 输出将为“h55o0dxfmj k ”。
有人可以帮我找出这种“魔法”的原因吗?