欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java使用正則表達(dá)式過濾html標(biāo)簽

 更新時(shí)間:2016年11月18日 14:46:04   作者:Devin Zhang  
本篇文章主要介紹了java正則表達(dá)式過濾html標(biāo)簽,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

前段時(shí)間開發(fā)的時(shí)候要讀取一篇文章的簡(jiǎn)介內(nèi)容(也就是前200個(gè)字符),使用了隱藏字段,可能有人就要問了,那后臺(tái)也是可以截取字符的啊,那是因?yàn)榫庉嬈骼锩姘薶tml標(biāo)簽,所以后臺(tái)就需要處理html標(biāo)簽的正則表達(dá)式,前些天上網(wǎng)搜了下,發(fā)現(xiàn)有人寫好的一個(gè)類,給大家共享下,不要閑小弟落伍了...

import java.util.regex.Matcher; 
import java.util.regex.Pattern; 
 
/** 
 * <p> 
 * Title: HTML相關(guān)的正則表達(dá)式工具類 
 * </p> 
 * <p> 
 * Description: 包括過濾HTML標(biāo)記,轉(zhuǎn)換HTML標(biāo)記,替換特定HTML標(biāo)記 
 * </p> 
 * <p> 
 * Copyright: Copyright (c) 2006 
 * </p> 
 * 
 * @author hejian 
 * @version 1.0 
 * @createtime 2006-10-16 
 */ 
 
public class HtmlRegexpUtil { 
 private final static String regxpForHtml = "<([^>]*)>"; // 過濾所有以<開頭以>結(jié)尾的標(biāo)簽 
 
 private final static String regxpForImgTag = "<\\s*img\\s+([^>]*)\\s*>"; // 找出IMG標(biāo)簽 
 
 private final static String regxpForImaTagSrcAttrib = "src=\"([^\"]+)\""; // 找出IMG標(biāo)簽的SRC屬性 
 
 /** 
  * 
  */ 
 public HtmlRegexpUtil() { 
  // TODO Auto-generated constructor stub 
 } 
 
 /** 
  * 
  * 基本功能:替換標(biāo)記以正常顯示 
  * <p> 
  * 
  * @param input 
  * @return String 
  */ 
 public String replaceTag(String input) { 
  if (!hasSpecialChars(input)) { 
   return input; 
  } 
  StringBuffer filtered = new StringBuffer(input.length()); 
  char c; 
  for (int i = 0; i <= input.length() - 1; i++) { 
   c = input.charAt(i); 
   switch (c) { 
   case '<': 
    filtered.append("&lt;"); 
    break; 
   case '>': 
    filtered.append("&gt;"); 
    break; 
   case '"': 
    filtered.append("&quot;"); 
    break; 
   case '&': 
    filtered.append("&amp;"); 
    break; 
   default: 
    filtered.append(c); 
   } 
 
  } 
  return (filtered.toString()); 
 } 
 
 /** 
  * 
  * 基本功能:判斷標(biāo)記是否存在 
  * <p> 
  * 
  * @param input 
  * @return boolean 
  */ 
 public boolean hasSpecialChars(String input) { 
  boolean flag = false; 
  if ((input != null) && (input.length() > 0)) { 
   char c; 
   for (int i = 0; i <= input.length() - 1; i++) { 
    c = input.charAt(i); 
    switch (c) { 
    case '>': 
     flag = true; 
     break; 
    case '<': 
     flag = true; 
     break; 
    case '"': 
     flag = true; 
     break; 
    case '&': 
     flag = true; 
     break; 
    } 
   } 
  } 
  return flag; 
 } 
 
 /** 
  * 
  * 基本功能:過濾所有以"<"開頭以">"結(jié)尾的標(biāo)簽 
  * <p> 
  * 
  * @param str 
  * @return String 
  */ 
 public static String filterHtml(String str) { 
  Pattern pattern = Pattern.compile(regxpForHtml); 
  Matcher matcher = pattern.matcher(str); 
  StringBuffer sb = new StringBuffer(); 
  boolean result1 = matcher.find(); 
  while (result1) { 
   matcher.appendReplacement(sb, ""); 
   result1 = matcher.find(); 
  } 
  matcher.appendTail(sb); 
  return sb.toString(); 
 } 
 
 /** 
  * 
  * 基本功能:過濾指定標(biāo)簽 
  * <p> 
  * 
  * @param str 
  * @param tag 
  *   指定標(biāo)簽 
  * @return String 
  */ 
 public static String fiterHtmlTag(String str, String tag) { 
  String regxp = "<\\s*" + tag + "\\s+([^>]*)\\s*>"; 
  Pattern pattern = Pattern.compile(regxp); 
  Matcher matcher = pattern.matcher(str); 
  StringBuffer sb = new StringBuffer(); 
  boolean result1 = matcher.find(); 
  while (result1) { 
   matcher.appendReplacement(sb, ""); 
   result1 = matcher.find(); 
  } 
  matcher.appendTail(sb); 
  return sb.toString(); 
 } 
 
 /** 
  * 
  * 基本功能:替換指定的標(biāo)簽 
  * <p> 
  * 
  * @param str 
  * @param beforeTag 
  *   要替換的標(biāo)簽 
  * @param tagAttrib 
  *   要替換的標(biāo)簽屬性值 
  * @param startTag 
  *   新標(biāo)簽開始標(biāo)記 
  * @param endTag 
  *   新標(biāo)簽結(jié)束標(biāo)記 
  * @return String 
  * @如:替換img標(biāo)簽的src屬性值為[img]屬性值[/img] 
  */ 
 public static String replaceHtmlTag(String str, String beforeTag, 
   String tagAttrib, String startTag, String endTag) { 
  String regxpForTag = "<\\s*" + beforeTag + "\\s+([^>]*)\\s*>"; 
  String regxpForTagAttrib = tagAttrib + "=\"([^\"]+)\""; 
  Pattern patternForTag = Pattern.compile(regxpForTag); 
  Pattern patternForAttrib = Pattern.compile(regxpForTagAttrib); 
  Matcher matcherForTag = patternForTag.matcher(str); 
  StringBuffer sb = new StringBuffer(); 
  boolean result = matcherForTag.find(); 
  while (result) { 
   StringBuffer sbreplace = new StringBuffer(); 
   Matcher matcherForAttrib = patternForAttrib.matcher(matcherForTag 
     .group(1)); 
   if (matcherForAttrib.find()) { 
    matcherForAttrib.appendReplacement(sbreplace, startTag 
      + matcherForAttrib.group(1) + endTag); 
   } 
   matcherForTag.appendReplacement(sb, sbreplace.toString()); 
   result = matcherForTag.find(); 
  } 
  matcherForTag.appendTail(sb); 
  return sb.toString(); 
 } 
} 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論