package com.gh.common.util; import android.text.TextUtils; import java.util.regex.Matcher; import java.util.regex.Pattern; /** * Created by khy on 27/12/17. */ public class HtmlUtils { public static String stripHtml(String htmlStr) { if (TextUtils.isEmpty(htmlStr)) return ""; String regEx_script = "]*?>[\\s\\S]*?<\\/script>"; //定义script的正则表达式 String regEx_style = "]*?>[\\s\\S]*?<\\/style>"; //定义style的正则表达式 String regEx_html = "<[^>]+>"; //定义HTML标签的正则表达式 Pattern p_script = Pattern.compile(regEx_script, Pattern.CASE_INSENSITIVE); Matcher m_script = p_script.matcher(htmlStr); htmlStr = m_script.replaceAll(""); //过滤script标签 Pattern p_style = Pattern.compile(regEx_style, Pattern.CASE_INSENSITIVE); Matcher m_style = p_style.matcher(htmlStr); htmlStr = m_style.replaceAll(""); //过滤style标签 Pattern p_html = Pattern.compile(regEx_html, Pattern.CASE_INSENSITIVE); Matcher m_html = p_html.matcher(htmlStr); htmlStr = m_html.replaceAll(""); //过滤html标签 return htmlStr.trim(); //返回文本字符串 } /** * 去除html代码及文本 */ public static String stripHtmlCode(String htmlStr) { if (TextUtils.isEmpty(htmlStr)) return ""; String regEx_script = "]*?>[\\s\\S]*?<\\/script>"; //定义script的正则表达式 String regEx_style = "]*?>[\\s\\S]*?<\\/style>"; //定义style的正则表达式 String regEx_html = "<[^>]+>[\\s\\S]*?<\\/[^>]+>"; //定义HTML标签的正则表达式 String regEx_html_single = "<[^>]+>"; //定义HTML单标签的正则表达式 String regEx_blank = "\\s+"; //定义空白字符的正则表达式 Pattern p_script = Pattern.compile(regEx_script, Pattern.CASE_INSENSITIVE); Matcher m_script = p_script.matcher(htmlStr); htmlStr = m_script.replaceAll(""); //过滤script标签 Pattern p_style = Pattern.compile(regEx_style, Pattern.CASE_INSENSITIVE); Matcher m_style = p_style.matcher(htmlStr); htmlStr = m_style.replaceAll(""); //过滤style标签 Pattern p_html = Pattern.compile(regEx_html, Pattern.CASE_INSENSITIVE); Matcher m_html = p_html.matcher(htmlStr); htmlStr = m_html.replaceAll(""); //过滤html标签 Pattern p_html_single = Pattern.compile(regEx_html_single, Pattern.CASE_INSENSITIVE); Matcher m_html_single = p_html_single.matcher(htmlStr); htmlStr = m_html_single.replaceAll(""); //过滤html单标签 Pattern p_blank = Pattern.compile(regEx_blank, Pattern.CASE_INSENSITIVE); Matcher m_blank = p_blank.matcher(htmlStr); htmlStr = m_blank.replaceAll(" ");//过滤空白字符 return htmlStr.trim(); //返回文本字符串 } /** * 过滤掉标签,保留标签内容 */ public static String filterHtmlLabel(String htmlStr) { String regEx_html = "<[^>]+>([\\s\\S]*?)<\\/[^>]+>"; //定义HTML标签的正则表达式 Pattern p_html = Pattern.compile(regEx_html, Pattern.CASE_INSENSITIVE); Matcher m_html = p_html.matcher(htmlStr); htmlStr = m_html.replaceAll("$1"); //过滤html标签 return htmlStr.trim(); //返回文本字符串 } }