URL传递中⽂字符,特殊危险字符的解决⽅案(仅供参考)urldecode、
base64_e。。。
很多时候,我们需要在url中传递中⽂字符或是其它的html等特殊字符,似乎总会有各种乱,不同的浏览器对他们的编码⼜不⼀样,
对于中⽂,⼀般的做法是:
把这些⽂本字符串传给url之前,先进⾏urlencode($text)⼀下;
但是对于⼀些很“危险”的字符,⽐如说html字符,甚⾄是SQL注⼊相关的字符,如果很明显的传给系统,出于安全考虑,系统⼀般都会把它们过滤掉的。
现在,我们需要这些危险字符,该这么办?
我想到的办法是先给它们base64_encode($text)编码,到服务端时,⼜给它们base64_decode($text)解码,
貌似很完美,但是在使⽤的过程中⼜遇到⼀个问题,base64_encode编码后的字符串中含有 "/", "+", "=" 等字符,
这些字符在url编码中⼜是特殊字符,⽐如 "+" ,它就表⽰ “空格”,但是不同的浏览器对“空格”的编码⼜不⼀样,有的是⽤“+”表⽰,有的是⽤“20%”表⽰,也就是说,让这些base64_encode编码后的字符串在url中传递,⽤不同的浏览器去浏览时,服务端得到值不⼀样。
于是乎,想到了⼀个折中办法,先将这些base64编码后的特殊字符替换掉,到服务端后,⼜替换回来:
<?php
function base_encode($str) {
$src = array("/", "+", "=");
在线url网址编码解码$dist = array("_a", "_b", "_c");
$old = base64_encode($str);
$new = str_replace($src, $dist, $old);
return $new;
}
function base_decode($str) {
$src = array("_a", "_b", "_c");
$dist = array("/", "+", "=");
$old = str_replace($src, $dist, $str);
$new = base64_decode($old);
return $new;
}
下⾯是在浏览器中得到的效果
xOO6w6Osuf65_aiy_atL_b00Ke5_b8jnus6ho6GjoaM_c
呵呵,看看效果如何。。。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论