在进入主题之前我们先来看这样如下代码,test.php
<?php $url = "test2.php?name=".base64_encode('用来做测试的字符串')."&age=23"; header("Location:$url");
<?php var_dump(base64_decode($_GET['name'])); die();
string ‘用来做测??y??9ke??)?.,‘ (length=26)
怎么回事,base64_decode无法解码?
仔细观察重定向后的地址中加密后的name参数,其中包含“+”符号,而浏览器的地址栏中碰到“+”符号时会将加号转换为空格,于是要保证base64_decode进行正确的解码操作,我们可以先将参数中的空格替换成加号,如下代码所示:
<?php $replaces = array(' ' => '+' ); var_dump(base64_decode(strtr( $_GET['name'], $replaces))); die();得到正确的输出结果:
string ‘用来做测试的字符串‘ (length=27)
版权声明:本文为博主原创文章,未经博主允许不得转载。
php函数base64_encode后的参数包含加号解析出错的解决方案
原文地址:http://blog.csdn.net/u011250882/article/details/47069521