前台将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
~!*()
这个函数是最常用的