为什么POST过来的sha1加密字符串相等的判断不对呢。

原创
2016-06-23 14:12:53 1408浏览

比如我表单post过来了sha1('1')这个加密后的字符串356a192b7913b04c54574d18c28d46e6395428ab。
然后我if($_POST['s']=='356a192b7913b04c54574d18c28d46e6395428ab')
为什么判断为false?
echo $_POST['s']也是356a192b7913b04c54574d18c28d46e6395428ab啊。。


回复讨论(解决方案)

仔细检查一下 $_POST['s'] 是不是那个值

仔细检查一下 $_POST['s'] 是不是那个值 我对过的没错阿。。。我在BAE试的。。一直不明白为什么。。。

你不如用 var_dump() 看看是否包含了空格换行什么的

你不如用 var_dump() 看看是否包含了空格换行什么的
没有的。。而且我也用trim()过滤了的说。。你能不能帮我看看呢。http://hole.icnu.me/t1.php

我复制他的var_dump()输出的引号+值就可以是true。
自己手打引号就是false。。。这是为什么啊??

贴出你的代码,可能不是你说的原因

贴出你的代码,可能不是你说的原因
t.php的代码。。

';var_dump($_POST['set']);if($_POST['set']=="f45918a75f152c9ce0b58043d5e5d7f22358665c")echo 'qw';?>

就是if里面那个双引号手打就false。。不知为什么。。。
http://hole.icnu.me/t1.php 这里post到t.php

贴出你的代码,可能不是你说的原因
应该是编码问题了。转换编码可以了。。


贴出你的代码,可能不是你说的原因
应该是编码问题了。转换编码可以了。。

错了错了。。。我也不知道为什么了。。。

我要重新描述一下了。。。
sha1加密后的字符应该是40个的
post过来后的怎么就变成43个字符了。。。?
在后面的页面重新加密的也是40个字符的。。
但是如果直接把指针指定一个那个加密后的字符串也是43个字符。。。
为什么?

var_dump()post过来的数据
string(43) "?356a192b7913b04c54574d18c28d46e6395428ab"
var_dump(sha1('1'))
string(40) "356a192b7913b04c54574d18c28d46e6395428ab"
var_dump('356a192b7913b04c54574d18c28d46e6395428ab')
string(43) "?356a192b7913b04c54574d18c28d46e6395428ab"

你 echo pack('H*', $_POST['set']); 看一下结果

你 echo pack('H*', $_POST['set']); 看一下结果

不好意思,我弄错了!
这样:
print_r(unpack('H*', $_POST['set']));

不好意思,我弄错了!
这样:
print_r(unpack('H*', $_POST['set']));

Array ( [1] => efbbbf33353661313932623739313362303463353435373464313863323864343665363339353432386162 )

Array ( [1] => efbbbf33353661313932623739313362303463353435373464313863323864343665363339353432386162 )

这个 efbbbf 是 utf-8 的 BOM 头
你去掉相关文件的 BOM 头就可以了

Array ( [1] => efbbbf33353661313932623739313362303463353435373464313863323864343665363339353432386162 )

这个 efbbbf 是 utf-8 的 BOM 头
你去掉相关文件的 BOM 头就可以了

谢了~~

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。