php过滤所有html标签的几种方法
用正则过滤html标签
<?php $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(" ", '', $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/code/33529.html
转载随意~请带上教程地址吧^^