今天在跟服务器的同学联调接口时,发现了个极其坑爹的BUG,传递给服务器的参数中如果有空格,就会报错,如果没有空格就一切正常。
检查了N久才最终发现是URLEncode的问题:
iOS转义完成后,参数中的空格被转义成了“%20”,而服务端转义完成后,参数中的空格被转义成了“+”;
在Stack Overflow上找到了详细点的解释:URL encoding the space character: + or %20?
简单来说就是:%20是比较老一点的写法,现在的做法是:url中的“?”前的空格要转义成“%20”,“?”之后的空格要转义成“+”!
而java的系统自带方法也是这么做的;但iOS系统自带的[str stringByAddingPercentEncodingWithAllowedCharacters:[NSCharacterSet URLQueryAllowedCharacterSet]];
方法还是将空格转义成了“%20”.
本来服务端是兼容“%20”这种转义方式的,
但这边为了安全自己做了转义,所以才会踩到这个坑;
记录一下,希望可以帮到有缘人~