用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php过滤所有html标签的几种方法

时间:2015-01-23  来源:西部数据  作者:西部数据

用正则过滤html标签,代码如下:

$html_body ="<a href='#'>www.phpfensi.com</a>";

preg_replace("/(</?)(w+)([^>]*>)/e", "'\1'.strtoupper('\2').'\3'",$html_body);

用php自带函数strip_tags,代码如下:

echo strip_tags("hello <b>world!www.phpfensi.com</b>");

用户自定义,代码如下:

  1. function filterhtml($str) { 
  2.         $str=eregi_replace("</*[^<>]*>"''$str); 
  3.         $str=str_replace(" "''$str); 
  4.         $str=str_replace(" "''$str); 
  5.         $str=str_replace(" "''$str); 
  6.         $str=str_replace("::"':'$str); 
  7.         $str=str_replace(" "''$str); 
  8.    //$str=str_replace("&nbsp;", '', $str); 
  9.         return $str

其它可能对你有用的方法.

1,过滤所有html标签的正则表达式,代码如下:

</?[^>]+>

2,过滤所有html标签的属性的正则表达式,代码如下:

$html = preg_replace("/<([a-za-z]+)[^>]*>/","<\1>",$html);

3,过滤部分html标签的正则表达式的排除式(比如排除<p>,即不过滤<p>),代码如下:

</?[^pp/>]+>

4,过滤部分html标签的正则表达式的枚举式(比如需要过滤<a><p><b>等),代码如下:

</?[aappbb][^>]*>

5,过滤部分html标签的属性的正则表达式的排除式(比如排除alt属性,即不过滤alt属性),代码如下:

s(?!alt)[a-za-z]+=[^s]*

6,过滤部分html标签的属性的正则表达式的枚举式(比如alt属性),代码如下:

(s)alt=[^s]*

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门