gpt4 book ai didi

java - URLDecode.decode 方法在 Java 中未按预期工作

转载 作者:行者123 更新时间:2023-12-02 01:59:56 25 4
gpt4 key购买 nike

我试图解码 URL 编码的帖子正文并遇到了这个问题。

我使用此方法进行解码(它也解码多个编码的网址):

public static String decodeUrl(String url)
{
try {
String prevURL="";
String decodeURL=url;
while(!prevURL.equals(decodeURL))
{
prevURL=decodeURL;
decodeURL= URLDecoder.decode( decodeURL, "UTF-8" );
}
return decodeURL;
} catch (UnsupportedEncodingException e) {
return "Issue while decoding" +e.getMessage();
}
}

当输入网址为“a%20%2B%20b%20%3D%3D%2013%25!”时,在调试时,该控件在 decodeURL = 行之后不显示。也不会引发任何异常。

问题是控制没有超出“decodeURL”行。

什么可能导致这个问题?请使用调试器来模拟这个问题。

最佳答案

刚刚在 Java 8u151 上进行了测试。这会在循环的第二次旋转时引发 IllegalArgumentException:“URLDecoder:不完整的尾随转义 (%) 模式”。这是因为在第一次解码后,您得到“a + b == 13%!”,而在第二次解码期间,% 应该引入编码序列,但事实并非如此。我认为这是预期的行为,即使其他语言的标准库不同意。以Python 3.6为例:

>>> from urllib.parse import unquote
>>> result = unquote('a%20%2B%20b%20%3D%3D%2013%25!')
>>> result
'a + b == 13%!'
>>> unquote(result)
'a + b == 13%!'

关于java - URLDecode.decode 方法在 Java 中未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51753729/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com