首页 > php开发 > php过滤所有html标签的几种方法

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

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

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

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

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

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

用户自定义,代码如下:

function filterhtml($str) { 
    $str=eregi_replace("</*[^<>]*>", '', $str); 
    $str=str_replace(" ", '', $str); 
    $str=str_replace(" ", '', $str); 
    $str=str_replace(" ", '', $str); 
    $str=str_replace("::", ':', $str); 
    $str=str_replace(" ", '', $str); 
   //$str=str_replace("&nbsp;", '', $str); 
    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]*


文章网址:http://www.phprm.com/develop/fs4360.html

随意转载^^但请附上教程地址。

标签:html标签 php过滤

发表留言