天天看点

URL中的特殊字符问题

js对文字进行编码涉及3个函数:escape,encodeuri,encodeuricomponent ,相应3个解码函数:unescape,decodeuri,decodeuricomponent

1、   传递参数时需要使用 encodeuricomponent,这样组合的url才不会被#等特殊字符截断。                            

2、   进行url跳转时可以整体使用 encodeuri

例如:location.href=encodeuri("http://cang.baidu.com/do/s?word=百度& amp;ct=21");

3、   js使用数据时可以使用escape

例如:搜藏中history纪录。

4、   escape对0-255以外的 unicode值进行编码时输出%u****格式,其它情况下 escape,encodeuri,encodeuricomponent编码结果相同。

最多使用的应为encodeuricomponent,它是将中文、韩文等特殊字符转换成utf-8格式的 url编码,所以如果给后台传递参数需要使用encodeuricomponent时需要后台解码对utf-8支 持(form中的编码方式和当前页面编码方式相同)

escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,a-z

encodeuri不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a- z,a-z

encodeuricomponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,a-z

URL中的特殊字符问题

<?php  

public function urlsafeb64encode($url) {   

    return strtr(base64_encode($url), '+/=', '-_,');  

}  

public function urlsafeb64decode($url) {  

    return base64_decode(strtr($url, '-_,', '+/='));  

urlencode,urldecode函数用于对urldecode编码过的字符串进行解码,然后返回。

URL中的特殊字符问题

<script>  

alert(unescape('\u5bf9\u4e0d\u8d77,\u60a8\u6ca1\u6709\u6267\u884c\u6b64\u9879\u64cd\u4f5c\u7684\u6743\u9650!'));  

</script>  

上一篇: 日期控件