相关疑难解决方法(0)

如何在Java中解析这样的URI

我正在尝试解析以下URI:http://translate.google.com/#zh-CN | en |你

但收到此错误消息:

java.net.URISyntaxException: Illegal character in fragment at index 34: http://translate.google.com/#zh-CN|en|?
        at java.net.URI$Parser.fail(URI.java:2809)
        at java.net.URI$Parser.checkChars(URI.java:2982)
        at java.net.URI$Parser.parse(URI.java:3028)
Run Code Online (Sandbox Code Playgroud)

它有问题"|" 如果我摆脱"|",最后一个中文字符没有引起任何问题,处理这个问题的正确方法是什么?

我的方法看起来像这样:

  public static void displayFileOrUrlInBrowser(String File_Or_Url)
  {
    try { Desktop.getDesktop().browse(new URI(File_Or_Url.replace(" ","%20").replace("^","%5E"))); }
    catch (Exception e) { e.printStackTrace(); }
  }
Run Code Online (Sandbox Code Playgroud)

谢谢你的答案,但BalusC的解决方案似乎只适用于url的一个实例,我的方法需要使用我传递给它的任何url,它怎么知道将url切成两部分的起点在哪里只编码第二部分?

java parsing uri

8
推荐指数
4
解决办法
3万
查看次数

标签 统计

java ×1

parsing ×1

uri ×1