java 过滤html标签

package com.xsl.util.tool;

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

public class HtmlScript{
	public static String delHTMLTag(String htmlStr){
	    String regEx_script="<script[^>]*?>[\\s\\S]*?<\\/script>"; //定义script的正则表达式
	    String regEx_style="<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代码。<br>
	*要求数据要规范,比如大于小于号要配套,否则会被集体误杀。
	* 
	*@paramcontent
	*     内容
	*@return去掉后的内容
	*/
public static String stripHtml(String content){
	//<p>段落替换为换行
	content=content.replaceAll("<p.*?>","");
	//<br><br/>替换为换行  
	content=content.replaceAll("<brs*/?>","");
	//去掉其它的<>之间的东西 
	content=content.replaceAll("<.*?>","");
	//还原HTML//content=HTMLDecoder.decode(content); 
	return content;
	}

public static String replaceHtml(String html){ 
    String regEx="<.+?>"; //表示标签 
    Pattern p=Pattern.compile(regEx); 
    Matcher m=p.matcher(html); 
    String s=m.replaceAll(""); 
    return s; 
}

	//public static void main(String[] args) {
//		String s = "<!DOCTYPE html PUBLIC ''-//WAPFORUM//DTD XHTML Mobile 1.0//EN'' ''http://www.wapforum.org/DTD/xhtml-mobile10.dtd''><html xmlns=''http://www.w3.org/1999/xhtml''><head><meta http-equiv=''Content-Type'' content=''text/html; charset=utf-8'' /><meta id=''viewport'' name=''viewport'' content=''width=320,initial-scale=1,maximum-scale=1,user-scalable=0;'' /><title>概述-白塞病诊断和治疗指南</title><link href=''Pub/css/layout.css'' rel=''stylesheet'' type=''text/css'' /><link href=''Pub/css/public.css'' rel=''stylesheet'' type=''text/css'' /><script type=''text/javascript'' src=''Pub/js/jquery-1.6.1.min.js''></script><script type=''text/javascript'' src=''Pub/js/base.js''></script></head><body><div id=''Layout''><div class=''titleBar''><h1 id= ''1''>1. 概述</h1></div><div class=''mainContainer''><p>白塞病(Behcet's disease,BD)又称贝赫切特病、口-眼-生殖器三联征等。是一种慢性全身性血管炎症性疾病,主要表现为复发性口腔溃疡、生殖器溃疡、眼炎及皮肤损害,也可累及血管、神经系统、消化道、关节、肺、肾、附睾等器官,大部分患者预后良好,眼、中枢神经系统及大血管受累者预后不佳。<br/><br/>本病在东亚、中东和地中海地区发病率较高,又被称为丝绸之路病。好发年龄为16~40岁。男性患者血管、神经系统及眼受累较女性多且病情重。</p></div></div></body></html>";
//		delHTMLTag(s);
	//System.out.println(delHTMLTag(s));
	//}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值