Web里URL空格的转换方法
程序员文章站
2024-03-01 15:08:58
看url是httputility.urlencode将空格转换成了“+”号,原因找到就着手解决bug。引用:复制代码 代码如下: filename = httputili...
看url是httputility.urlencode将空格转换成了“+”号,原因找到就着手解决bug。
引用:
复制代码 代码如下:
filename = httputility.urlencode(filename, encoding.utf8);
filename = filename.replace("+", "%20");
通过replace替换解决,虽然问题解决了,但这并不是一个很好的方法,如果文件夹或文件名中包含“+”号则会导致另外的bug发生。
最佳解决方案:
使用httputility.urlpathencode,urlpathencode 方法执行下列步骤:
1.将 urlpathencode 方法的编码逻辑只应用于 url 的路径部分(不包括查询字符串)。 该方法假定 url 被编码为 utf-8 字符串。
2.对非空格编码,以便在所得的编码字符串中使用前 128 个 ascii 字符的子集。 unicode 的所有字符值为 128 及更高,或者 32 和更小, url 中输入。
3.输入空格作为 %20。
使用 urlencode 方法或 urlpathencode 方法,可以输入 url。 但是,方法返回不同的结果。 urlencode 方法将每个空格字符转换为加号 (+) 字符。 urlpathencode 方法将每个空格字符转换为字符串 %20,以十六进制表示法表示的一个空格。 在对 url 的路径部分编码时使用 urlpathencode 方法,以保证一致的已解码 url,与执行解码的平台或浏览器无关。 当您使用 urlpathencode 方法时,查询字符串值不会输入。 因此,可通过问号的任何值 (?) 在字符串,将不会输入。 如果必须通过 url,当查询字符串,则使用 urlencode 方法。
看到项目中很多页面都使用了replace方式,查询后全部替换为urlpathencode减少更多bug的发生。