php过滤所有html标签的几种方法
用正则过滤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>");
用户自定义,代码如下:
- 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(" ", '', $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]*