亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java識別和處理HTML標(biāo)簽內(nèi)容的常用方法

 更新時間:2025年07月07日 09:49:57   作者:白大鍋  
這篇文章總結(jié)了識別和處理HTML的幾種方法:推薦使用Jsoup處理復(fù)雜結(jié)構(gòu),因其功能強大且API友好;避免正則表達式和XML解析器處理嵌套標(biāo)簽;需清理用戶輸入中的潛在安全風(fēng)險,并注意字符編碼問題,需要的朋友可以參考下

1. 使用正則表達式(簡單場景)

適用于簡單的 HTML 標(biāo)簽識別和提?。?/p>

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class HtmlTagExtractor {
    public static void main(String[] args) {
        String html = "<div><p>Hello <b>World</b></p><a href='example.com'>Link</a></div>";
        
        // 匹配所有標(biāo)簽
        Pattern tagPattern = Pattern.compile("<[^>]+>");
        Matcher tagMatcher = tagPattern.matcher(html);
        
        System.out.println("所有HTML標(biāo)簽:");
        while (tagMatcher.find()) {
            System.out.println(tagMatcher.group());
        }
        
        // 匹配特定標(biāo)簽(如<a>標(biāo)簽)
        Pattern aTagPattern = Pattern.compile("<a\\b[^>]*>(.*?)</a>");
        Matcher aTagMatcher = aTagPattern.matcher(html);
        
        System.out.println("\n所有<a>標(biāo)簽:");
        while (aTagMatcher.find()) {
            System.out.println("完整標(biāo)簽: " + aTagMatcher.group(0));
            System.out.println("標(biāo)簽內(nèi)容: " + aTagMatcher.group(1));
        }
        
        // 匹配標(biāo)簽屬性
        Pattern attrPattern = Pattern.compile("\\b(href|src)=['\"]([^'\"]*)['\"]");
        Matcher attrMatcher = attrPattern.matcher(html);
        
        System.out.println("\n所有href/src屬性:");
        while (attrMatcher.find()) {
            System.out.println(attrMatcher.group(1) + " = " + attrMatcher.group(2));
        }
    }
}

注意:正則表達式不適合處理復(fù)雜的、嵌套的 HTML 結(jié)構(gòu)。

2. 使用 Jsoup(推薦)

Jsoup 是一個強大的 Java HTML 解析庫:

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

public class JsoupExample {
    public static void main(String[] args) {
        String html = "<html><head><title>Sample</title></head>"
                + "<body><div id='content'><p class='text'>First paragraph</p>"
                + "<p>Second <b>paragraph</b></p><a href='example.com'>Link</a></div></body></html>";
        
        // 解析HTML
        Document doc = Jsoup.parse(html);
        
        // 獲取標(biāo)題
        System.out.println("標(biāo)題: " + doc.title());
        
        // 獲取所有段落
        Elements paragraphs = doc.select("p");
        System.out.println("\n所有段落:");
        for (Element p : paragraphs) {
            System.out.println(p.text());
        }
        
        // 獲取特定ID的元素
        Element contentDiv = doc.getElementById("content");
        System.out.println("\nID為content的div:");
        System.out.println(contentDiv.html());
        
        // 獲取特定class的元素
        Elements textElements = doc.getElementsByClass("text");
        System.out.println("\nclass為text的元素:");
        for (Element el : textElements) {
            System.out.println(el.text());
        }
        
        // 獲取所有鏈接
        Elements links = doc.select("a[href]");
        System.out.println("\n所有鏈接:");
        for (Element link : links) {
            System.out.println("文本: " + link.text() + ", 鏈接: " + link.attr("href"));
        }
        
        // 獲取元素的父級和子級
        Element firstP = paragraphs.first();
        System.out.println("\n第一個段落的父元素: " + firstP.parent().tagName());
        System.out.println("第一個段落的子元素數(shù)量: " + firstP.children().size());
    }
}

3. 使用 JDK 內(nèi)置的 XML 解析器(適用于 XHTML)

對于格式良好的 XHTML,可以使用 JDK 內(nèi)置的 XML 解析器:

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;

public class XmlParserExample {
    public static void main(String[] args) throws Exception {
        String xhtml = "<html><body><p>Paragraph 1</p><p>Paragraph 2</p></body></html>";
        
        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        DocumentBuilder builder = factory.newDocumentBuilder();
        Document doc = builder.parse(new InputSource(new StringReader(xhtml)));
        
        // 獲取所有段落
        NodeList paragraphs = doc.getElementsByTagName("p");
        System.out.println("找到 " + paragraphs.getLength() + " 個段落:");
        
        for (int i = 0; i < paragraphs.getLength(); i++) {
            System.out.println(paragraphs.item(i).getTextContent());
        }
    }
}

4. 使用 HTMLCleaner

HTMLCleaner 是另一個輕量級的 HTML 解析庫:

import org.htmlcleaner.HtmlCleaner;
import org.htmlcleaner.TagNode;

public class HtmlCleanerExample {
    public static void main(String[] args) throws Exception {
        String html = "<html><body><div><p>Hello</p><p>World</p></div></body></html>";
        
        HtmlCleaner cleaner = new HtmlCleaner();
        TagNode rootNode = cleaner.clean(html);
        
        // 獲取所有段落
        TagNode[] paragraphs = rootNode.getElementsByName("p", true);
        System.out.println("找到 " + paragraphs.length + " 個段落:");
        
        for (TagNode p : paragraphs) {
            System.out.println(p.getText().toString());
        }
    }
}

5. 處理 HTML 文本(去除標(biāo)簽)

如果只需要提取文本內(nèi)容而不需要標(biāo)簽結(jié)構(gòu):

import org.jsoup.Jsoup;

public class HtmlTextExtractor {
    public static void main(String[] args) {
        String html = "<div><p>Hello <b>World</b></p><a href='example.com'>Link</a></div>";
        
        // 使用Jsoup提取文本
        String text = Jsoup.parse(html).text();
        System.out.println("純文本內(nèi)容:\n" + text);
        
        // 簡單正則方法去除標(biāo)簽(不推薦用于復(fù)雜HTML)
        String textOnly = html.replaceAll("<[^>]+>", "");
        System.out.println("\n簡單去除標(biāo)簽后的文本:\n" + textOnly);
    }
}

最佳實踐建議

  • 推薦使用 Jsoup:它功能強大、API友好,適合大多數(shù)HTML處理場景
  • 避免使用正則處理復(fù)雜HTML:正則表達式難以正確處理嵌套標(biāo)簽和格式不規(guī)范的HTML
  • 注意HTML清理:當(dāng)處理用戶輸入的HTML時,應(yīng)該清理潛在的惡意內(nèi)容
  • 考慮性能:對于大量HTML處理,Jsoup的性能通常足夠好
  • 處理編碼問題:確保正確處理HTML文檔的字符編碼

安全注意事項

當(dāng)處理用戶提供的HTML內(nèi)容時,務(wù)必考慮安全風(fēng)險:

import org.jsoup.Jsoup;
import org.jsoup.safety.Safelist;

public class HtmlSanitizer {
    public static void main(String[] args) {
        String unsafeHtml = "<div onclick='alert(\"xss\")'>Hello<script>alert('xss')</script><a href='javascript:alert(1)'>Link</a></div>";
        
        // 基本清理,只允許文本
        String safeText = Jsoup.clean(unsafeHtml, Safelist.none());
        System.out.println("僅文本:\n" + safeText);
        
        // 允許基本格式和安全的鏈接
        String basicHtml = Jsoup.clean(unsafeHtml, Safelist.basic());
        System.out.println("\n基本HTML:\n" + basicHtml);
        
        // 自定義白名單
        Safelist customList = Safelist.basic()
            .addTags("div", "span")
            .addAttributes("div", "class");
        String customClean = Jsoup.clean(unsafeHtml, customList);
        System.out.println("\n自定義清理:\n" + customClean);
    }
}

到此這篇關(guān)于Java識別和處理HTML標(biāo)簽內(nèi)容的常用方法的文章就介紹到這了,更多相關(guān)Java識別和處理HTML內(nèi)容內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mybatis xml如何使用not in 某個集合的格式

    mybatis xml如何使用not in 某個集合的格式

    這篇文章主要介紹了mybatis xml如何使用not in 某個集合的格式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • Java如何將文件內(nèi)容轉(zhuǎn)換為MD5哈希值

    Java如何將文件內(nèi)容轉(zhuǎn)換為MD5哈希值

    這篇文章主要介紹了Java如何將文件內(nèi)容轉(zhuǎn)換為MD5哈希值的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-05-05
  • Spring WebFlux之響應(yīng)式編程詳解

    Spring WebFlux之響應(yīng)式編程詳解

    這篇文章主要介紹了Spring WebFlux之響應(yīng)式編程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-03-03
  • java集合類遍歷的同時如何進行刪除操作

    java集合類遍歷的同時如何進行刪除操作

    這篇文章主要介紹了java集合類遍歷的同時如何進行刪除操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • java異常:異常處理--try-catch結(jié)構(gòu)詳解

    java異常:異常處理--try-catch結(jié)構(gòu)詳解

    今天小編就為大家分享一篇關(guān)于Java異常處理之try...catch...finally詳解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2021-09-09
  • java.time包時間類的具體使用

    java.time包時間類的具體使用

    本文主要介紹了java.time包時間類的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • Java中操作超大數(shù)的方法

    Java中操作超大數(shù)的方法

    本篇文章是小編在網(wǎng)上整理的關(guān)于java操作超大數(shù)的方法以及解決思路,有興趣的朋友參考學(xué)習(xí)下。
    2018-06-06
  • Java 滑動窗口最大值的實現(xiàn)

    Java 滑動窗口最大值的實現(xiàn)

    這篇文章主要介紹了Java 滑動窗口最大值,給定一個數(shù)組 nums,有一個大小為 k 的滑動窗口從數(shù)組的最左側(cè)移動到數(shù)組的最右側(cè)。感興趣的可以了解一下
    2021-05-05
  • java正則表達式使用示例

    java正則表達式使用示例

    這篇文章主要介紹了java正則表達式使用示例,實現(xiàn)拆分字符串、替換字符串、判斷字符串是否與制定模式匹配等功能,需要的朋友可以參考下
    2014-03-03
  • Java8 HashMap鍵與Comparable接口小結(jié)

    Java8 HashMap鍵與Comparable接口小結(jié)

    這篇文章主要介紹了Java8 HashMap鍵與Comparable接口小結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01

最新評論