URL中包含&字符时,出现两次转义效果
前台将URL作为参数传递给后台,传递前首先进行了一次encodeURIComponent的编码;
function urlencode (str) {
str = (str + "").toString();
return encodeURIComponent(str).replace(/!/g, "%21").replace(/"/g, "%27").replace(/(/g, "%28").
replace(/)/g, "%29").replace(/*/g, "%2A").replace(/%20/g, "+");
}
后台收到却不一致;
前台输入的URL中包含的&符号,在PHP中显示为&但是其他字符显示正常;
比如:input中输入http://1.2.3.4/&.com 将其作为参数传递,
PHP收到显示为 http://1.2.3.4/&.com
后来发现在浏览器传递的时候就已经出现了错误,原有的&符号,在浏览器中显示为&amp%3b;
即出现了两次转义的效果。
首先通过encodeURIComponent进行了一次转义,之后浏览器将&又进行了一次转义。
目前PHP采用str_replace手动替换"&"为‘&’。
以下从http://outofmemory.cn/code-snippet/1271/wanmei-javascript-URLEncode-function 看到的:
当需要通过查询字符串传值给服务器时需要对get参数进行encode。
- escape()函数,不会encode
@*/+
(不推荐使用) - encodeURI()函数,不会encode
~!@#$&*()=:/,;?+"
(不推荐使用) - encodeURIComponent()函数,不会encode
~!*()
这个函数是最常用的
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。