过滤html标签在php中可以有内置的函数了,但它过滤的太干净了,我们就整理了一下些利用正则来过滤指定html标签的例子,具体如下所示。
采集的时候有本文来源gaodaimacom搞#^代%!码&网*
搞代gaodaima码
时候需要过滤掉多余的标签属性,比如 img标签过滤掉除了src属性之外的所有属性例如删除titile alt等属性以及一些脚的onclick属性等。
例如
过滤除了src之外的所有属性:
<br />$str= preg_replace('/\s(?!src)[a-zA-Z]+=[\'\"]{1}[^\'\"]+[\'\"]{1}/iu',' $str); <br />
上面的实例代码是过滤掉除了src属性外的所有标签属性.
过滤设置过滤除了alt和src之外的所有属性
代码如下:
<br />$str = preg_replace('/\s(?!(src|alt))[a-zA-Z]+=[^\s]*/iu',' ', $str); <br />
过滤所有html标签的属性的正则表达式:
<br />$str = preg_replace("/]*>/i","",$str ); <br />
只过滤alt属性的正则表达式:
<br />(\s)alt=[^\s]* <br />
过滤所有html标签的属性的正则表达式:
<br />$search = array ("'<script[^>]*?>.*?</script>'si", // 去掉 javascript <br />"'<[\/\!]*?[^]*?>'si", // 去掉 HTML 标记 <br />"'([\r\n])[\s]+'", // 去掉空白字符 <br />"'&(quot|#34);'i", // 替换 HTML 实体 <br />"'&(amp|#38);'i", <br />"'&(lt|#60);'i", <br />"'&(gt|#62);'i", <br />"'&(nbsp|#160);'i" <br />); // 作为 PHP 代码运行 <br />$replace = array ("","","\\1","\"","&",""," "); <br />$html = preg_replace($search, $replace, $html); <br />