php中url传递中文字符,特殊危险字符的解决方法
我们需要在url中传递中文字符或是其它的html等特殊字符,似乎总会有各种乱,不同的浏览器对他们的编码又不一样, 对于中文,一般的做法是: 把这些文本字符串传给url之前,先进行urlencode($text)一下; 但是对于一些很“危险”的字符,比如说html字符,甚至是SQL注入相关的字符,如果很明显的传给系统,出于安全考虑,系统一般都会把它们过滤掉的。 现在,我们需要这些危险字符,该这么办? 我想到的办法是 先给它们 base64_encode($text) 编码,到服务端时,又给它们 base64_decode($text) 解码, 貌似很完美,但是在使用的过程中又遇到一个问题,base64_encode 编码后的字符串中含有 "/","+","=" 等字符,
用户提交加密: tPK9tNPNyKUsuse6xyYjNDY7JiM0NjsufMavwcEhfMyrxq/BwcHLLMjDztLO3tPvLNXmz+vI69ehsKEhfHw=
tPK9tNPNyKUsuse6xyYjNDY7JiM0NjsufMavwcEhfMyrxq/BwcHLLMjDztLO3tPvLNXmz vI69ehsKEhfHw= 对比找到少了一个加号,不知道是什么原因导制的(猜想可能是get时,+字符可能不能得到吧!).还请高手指点. 这些字符在url编码中又是特殊字符,比如 "+" ,它就表示 “空格”,但是不同的浏览器对“空格”的编码又不一样,有的是用“+”表示,有的是用“20%”表示,也就是说,让这些base64_encode编码后的字符串在url中传递,用不同的浏览器去浏览时,服务端得到值不一样。 于是乎,想到了一个折中办法,先将这些base64编码后的特殊字符替换掉,到服务端后,又替换回来:
一.在用户提交加密串的时间,我把+字符给换成别的字字符.如:str_replace('+','_',$content); 代码如下: function base_encode($str) { $src = array("/","="); $dist = array("_a","_b","_c"); $old = base64_encode($str); $new = str_replace($src,$dist,$old); return $new; }function base_decode($str) { $src = array("_a","_c"); $dist = array("/","="); $old = str_replace($src,$str); $new = base64_decode($old); return $new; } 下面是在浏览器中得到的效果 xOO6w6Osuf65_aiy_atL_b00Ke5_b8jnus6ho6GjoaM_c urldecode实例方法很简单 urldecode ( string $str ) Example #1 urldecode() 例子 代码如下: $a = explode('&',$QUERY_STRING); $i = 0; while ($i < count($a)) { $b = split('=',$a[$i]); echo 'Value for parameter ',htmlspecialchars(urldecode($b[0])), ' is ',htmlspecialchars(urldecode($b[1]))," "; $i++; } ?> (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |