有时候用base64_encode加密后,以GET的形式传到其他页面,用base64_decode解密的时候,出现乱码.
遇到这个问题的时候,我就纳闷了,为什么有一些能正确解密,但是有一些却出现乱码呢?
后来经过检查,发现有一些中文字符,用GET形式传过来的时候,+号会被替换成空格.
为了防止出现乱码的情况,我做了一步替换,然后再解密,果然,乱码的问题,不复存在了!
比如你以GET的形式传过来一个oid变量,那么解密还原的时候,先用+号替换空格.那么输出就正常了.
如下: $oid=base64_decode(str_replace(" ","+",$_GET[oid]));
本文探讨了在使用Base64进行加密和解密过程中遇到的乱码问题,尤其是在通过GET方式传递参数时,由于+号被替换成空格导致的解码错误。文章提供了一个简单的解决方案:在解码前将空格替换回+号。
2187

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



