php函数base64_encode后的参数包含加号解析出错的解决方案

WBOY
Freigeben: 2016-06-23 13:29:59
Original
1616 Leute haben es durchsucht

在进入主题之前我们先来看这样如下代码,test.php

<?php $url = "test2.php?name=".base64_encode('用来做测试的字符串')."&age=23";header("Location:$url");
Nach dem Login kopieren


test2.php

<?phpvar_dump (base64_decode($_GET['name']));die();
Nach dem Login kopieren

访问http://localhost/test.php地址时,重定向到http://localhost/test2.php?name=55So5p2l5YGa5rWL6K+V55qE5a2X56ym5Liy&age=23地址,浏览器输出结果为:

<pre class="n">string '用来做测??y??9ke??)?.,' (length=26)
Nach dem Login kopieren

怎么回事,base64_decode无法解码?


仔细观察重定向后的地址中加密后的name参数,其中包含“+”符号,而浏览器的地址栏中碰到“+”符号时会将加号转换为空格,于是要保证base64_decode进行正确的解码操作,我们可以先将参数中的空格替换成加号,如下代码所示:

<?php$replaces = array(' ' => '+' );var_dump(base64_decode(strtr( $_GET['name'], $replaces)));die();
Nach dem Login kopieren
得到正确的输出结果:

string '用来做测试的字符串' (length=27)
Nach dem Login kopieren



版权声明:本文为博主原创文章,未经博主允许不得转载。

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage