我已经搜索了一个小时,但我无法让它工作。
我有一个名为user
2 列的表username varchar(64)
,并且password binary(20)
. 我正在使用 SHA1 加密,因为我想让它变得又快又脏。
mysql> describe user;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| username | varchar(64) | NO | PRI | NULL | |
| password | binary(20) | NO | | NULL | |
+----------+-------------+------+-----+---------+-------+
当我想验证用户的密码时,我遇到了一些麻烦。我没有得到二进制的结果密码。有什么建议么?谢谢。
$username = mysql_real_escape_string($_POST['username']);
$password = sha1(mysql_real_escape_string($_POST['password']));
$binPass = pack("H*", $password);
$query = "SELECT * FROM `user` WHERE `username` = '$username' AND `password` = $binPass;";