1、看到很多同学分享,shell 计算字符串md5 的方法为:echo '123' | md5sum
echo '123' | md5sum
ba1f2511fc30423bdbb183fe33f3dd0f -
很遗憾,如果采用数据数据库计算md5 值,不一样。
mysql> select md5(123);
+----------------------------------+
| md5(123) |
+----------------------------------+
| 202cb962ac59075b964b07152d234b70 |
+----------------------------------+
2、问题来了为什么两种方式的结果不一致?
问题在于: echo默认是带换行符做结尾的。echo '123' | md5sum 计算的其实是 123加上换行的 md5值 ,而不是123 的md5值。
怎么办呢:echo -n 可以去掉换行符。如下正确:
echo -n '123' | md5sum
202cb962ac59075b964b07152d234b70 -
本文探讨了在Shell和MySQL环境中计算字符串MD5值时出现的不同结果。问题根源在于Shell的echo命令默认带有换行符,导致计算的是包含换行符的字符串MD5值。文章提供了正确的Shell命令用法,即使用echo -n去除换行符,确保与MySQL计算结果一致。
6695

被折叠的 条评论
为什么被折叠?



