url中包含中文处理

问题:项目中测试建了一个池名称为“山东#青岛”,通过url传递参数到后台直接就报错,原因是#把后面的字符链接给截断了,通过对#转义后在chrome和firefox浏览器可以正常传递使用,但是在IE浏览器下还是歇菜。虽然创建这样的名字很不合理,但确实是个bug,特别对于通过用户配置的参数,中文和转义字符很容易出现请求的url中。

解决方法:经过验证,采用 encodeURIComponent()可以完成参数编码,包括特殊字符串也无需单独转义,并且可以保证IE、chrome、firefox下均正常使用。

扩展:url编码函数主要有三个 escape()、encodeURI()、encodeURIComponent(),其中   
escape(): 采用ISO Latin字符集对指定的字符串进行编码。所有的空格符、标点符号、特殊字符以及其他非ASCII字符都会转化成%xx格式的字符编码(xx代表此字符在字符集表里编码的16进制数字)。比如,空格符的对应编码是%20。不会对ASCII字符和数字进行编码。不会被此方法编码的字符:@ * / +,反向编码函数:unescape()。 
encodeURI():把URI字符串采用UTF-8编码格式转化成escape格式的字符串。不会被此方法编码的字符:! @ # $ & ( ) = : / ; ? + ',反向编码函数:decodeURI()。       
encodeURIComponent():把URI字符串采用URF-8编码格式转化成escape格式的字符串。与encodeURI相比,这个函数会将更多的字符进行编码,比如"/"等字符。所以如果字符串里面包含了URI的几个部分的话,不能用这个来进行编码。否则“/”字符被编码后将URL显示错误。不会被此方法编码的字符:! * ( ),反向编码函数:decodeURIComponent()。

参考资料:

https://www.cnblogs.com/douJiangYouTiao888/p/6473874.html

https://www.cnblogs.com/huaxingtianxia/p/7125862.html

原创文章 33 获赞 6 访问量 2万+

猜你喜欢

转载自blog.csdn.net/lanyue1/article/details/89305550