我们知道发送一个http请求时,如果使用的是GET方法,请求的参数会包含在url中并通过&进行分割,如:http://www.example.com/index?name=name1&id=id2。服务端根据url中的参数获取对应的值。java编写的后台代码,可通过HttpServletRequest的方法getParameter("name")获取name的值:name=name1.
事实上HttpServletRequest获取参数是对字符串"?name=name1&id=id2"进行拆分,根据"&"分割出参数名称,根据"="分割出参数值。那么问题来了,如果我们的name里面本身就包含有&或者=,如name="na&me=1",如果发送http请求前不做相应的处理,url就变成了http://www.example.com/index?name=na&me=1&id=id2,这个时候后台解析出来的参数就变成了:name=na;me=1;id=id2,这显然不是我们想要的结果。
面对这个情况的解决方法是对url中存在歧义的字符串进行URL编码。URL编码就是使用一种安全的字符去表示不安全的或存在歧义的字符,”na&me=1"经过URL编码后的值为:na%26me%3d1,这个时候我们发送http请求的url改为:http://www.example.com/index?name=na%26me%3d1&id=id2,服务端进行解码后解析参数便可获得正确的值:name="na&me=1"。
接收URL参数时当其中有参数值含有#的时候,后面的参数就被截断,收不到值
因为"#"代表url的结束。在请求之前先替换“#”为其他字符例如"$"然后request的时候在替换为原来那个或者进行编码。
在url中直接使用一些特殊字符,如果字符为“a-z”,”A-Z”,”0-9”,”.”,”-“,”_”,”*”,则这些字符会直接被服务器识别,维持原值,如果是字符”+”,”/”,”?”,”%”,”#”,”&”,”=”,则它们将会被转码。那么我们就需要转码来让服务器进行识别。
编码js语法: encodeURI(URIstring)
解码js语法: decodeURI(URIstring)
参考:https://blog.csdn.net/qq_22855325/article/details/75335030
https://blog.csdn.net/weixin_34186950/article/details/92316158
https://blog.csdn.net/u011324293/article/details/53426549?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.control