您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/3/5 15:38:56发布38次查看
比如我表单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的代码。。

就是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 头就可以了
谢了~~
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product