我正在尝试使用 PHP 而不是 MYSQL 在数据库中添加键值
select unhex(md5('google.com')) from x;
输出
HVkg9LRLJ6gCvXfE8FNvWg==
但是使用 PHP
echo hex2bin((md5("google.com")));
输出
Y ��K'��w��SoZ
我不确定这里出了什么问题,有什么帮助吗?
Edit1 约阿希姆·伊萨克森
我不确定您是如何获得该值的,但是在 MySQL 提示符下进行选择会得到与 PHP 相同的值;
mysql> select unhex(md5('google.com'));
+--------------------------+
| unhex(md5('google.com')) |
+--------------------------+
| Y �K'��w��SoZ |
+--------------------------+
1 row in set (0.00 sec)
您显示的是同一事物的 base64 编码值;
mysql> select to_base64(unhex(md5('google.com')));
+-------------------------------------+
| to_base64(unhex(md5('google.com'))) |
+-------------------------------------+
| HVkg9LRLJ6gCvXfE8FNvWg== |
+-------------------------------------+
1 row in set (0.00 sec)
我不确定您的值如何进行 base64 编码,但它似乎与您显示的 MySQL 查询无关。这可能是由您在 PHP 中获取值的方式引起的。