首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL MD5选择

MySQL MD5选择
EN

Stack Overflow用户
提问于 2011-01-31 02:37:33
回答 3查看 86.5K关注 0票数 17

以下查询返回null。

代码语言:javascript
运行
复制
SELECT `email`, `password`, `salt` FROM `users` WHERE `password` = md5(`salt`+md5('123123'+`salt`)+'123123') AND `email` = 'xeka@xeka.ru'

以下查询返回'd2b4312db21705dafd96df14f8525fef',但为什么?

代码语言:javascript
运行
复制
SELECT md5( 'Vwm' + md5( '123123' + 'Vwm' ) + '123123' )  

此代码返回“422ad0c19a38ea88f4db5e1feaaa920”。

代码语言:javascript
运行
复制
$salt = 'Vwm';
$password = '123123';

echo md5($salt . md5($password . $salt) . $password);

进行用户授权。我如何创建一个数据库查询,让第一个拿到盐和盐的人有这个我做的一些MD5函数?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-01-31 02:47:26

代码语言:javascript
运行
复制
SELECT md5(CONCAT('Vwm', md5(CONCAT('123123', 'Vwm' )), '123123' )) ;

您需要连接字符串(),然后对它们执行md5()。

这样,它将正确地返回与PHP脚本相同的值:

代码语言:javascript
运行
复制
+--------------------------------------------------------------+
| md5(CONCAT('Vwm', md5(CONCAT('123123', 'Vwm' )), '123123' )) |
+--------------------------------------------------------------+
| 422ad0c19a38ea88f4db5e1fecaaa920                             |
+--------------------------------------------------------------+
票数 35
EN

Stack Overflow用户

发布于 2011-01-31 02:48:45

MySQL中的字符串连接需要使用CONCAT()`。这个;

代码语言:javascript
运行
复制
md5( '123123' + 'Vwm' )

实际上是将一个数字添加到字符串中:

代码语言:javascript
运行
复制
mysql> select '12123' + 'Vwm';
+-----------------+
| '12123' + 'Vwm' |
+-----------------+
|           12123 |
+-----------------+

因此,您的查询与PHP端不同,因为您没有散列相同的字符串。

票数 11
EN

Stack Overflow用户

发布于 2011-01-31 02:44:52

  • salt应该在您的脚本中
  • salt password在您的数据库中
  • 您的脚本是salt password,并与db
  • 中的salt版本进行比较如果相同,请考虑OK
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4844717

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档