jsoup - 處理 URL



以下示例將展示可提供 HTML 頁面中存在的相對和絕對 URL 的方法。

語法

String url = "https://tutorialspoint.tw/";
Document document = Jsoup.connect(url).get();
Element link = document.select("a").first();         

System.out.println("Relative Link: " + link.attr("href"));
System.out.println("Absolute Link: " + link.attr("abs:href"));
System.out.println("Absolute Link: " + link.absUrl("href"));

其中

  • document − 文件物件表示 HTML DOM。

  • Jsoup − 連線到 URL 並獲取 HTML 內容的主類。

  • link − 元素物件表示表示錨標記的 HTML 節點元素。

  • link.attr("href") − 提供錨標記中存在的 href 的值。它可能是相對的,也可能是絕對的。

  • link.attr("abs:href") − 根據針對文件的基本 URI 進行解析後提供絕對 URL。

  • link.absUrl("href") − 根據針對文件的基本 URI 進行解析後提供絕對 URL。

描述

元素物件表示 DOM 元素,並提供獲取 HTML 頁面中存在的相對和絕對 URL 的方法。

示例

在你選擇的任何編輯器(例如 C:/> jsoup)中建立以下 Java 程式。

JsoupTester.java

import java.io.IOException;

import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;

public class JsoupTester {
   public static void main(String[] args) throws IOException {
   
      String url = "https://tutorialspoint.tw/";
      Document document = Jsoup.connect(url).get();

      Element link = document.select("a").first();
      System.out.println("Relative Link: " + link.attr("href"));
      System.out.println("Absolute Link: " + link.attr("abs:href"));
      System.out.println("Absolute Link: " + link.absUrl("href"));
   }
}

驗證結果

使用 javac 編譯器編譯類,如下所示

C:\jsoup>javac JsoupTester.java

現在,執行 JsoupTester 檢視結果。

C:\jsoup>java JsoupTester

檢視結果。

Relative Link: index.htm
Absolute Link: https://tutorialspoint.tw/index.htm
Absolute Link: https://tutorialspoint.tw/index.htm
廣告