1

我正在尝试使用 PHP 而不是 MYSQL 在数据库中添加键值

select unhex(md5('google.com')) from x;

输出

HVkg9LRLJ6gCvXfE8FNvWg==

但是使用 PHP

echo hex2bin((md5("google.com")));

输出

Y ��K'��w��SoZ

我不确定这里出了什么问题,有什么帮助吗?

Edit1 约阿希姆·伊萨克森

在此处输入图像描述

4

1 回答 1

1

我不确定您是如何获得该值的,但是在 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 中获取值的方式引起的。

于 2016-03-27T09:29:42.283 回答