当前位置:首页 > PHP教程 > 正则表达式 > 列表

PHP正则表达式过滤html标签属性(DEMO)

发布:smiling 来源: PHP粉丝网  添加日期:2021-08-01 14:21:20 浏览: 评论:0 

这篇文章主要介绍了PHP正则表达式过滤html标签属性的相关内容,实用性非常,感兴趣的朋友参考下吧。

过滤html标签在php中可以有内置的函数了,但它过滤的太干净了,我们就整理了一下些利用正则来过滤指定html标签的例子,具体如下所示。

采集的时候有时候需要过滤掉多余的标签属性,比如 img标签过滤掉除了src属性之外的所有属性例如删除titile alt等属性以及一些脚的onclick属性等。

例如

过滤除了src之外的所有属性:

$str= preg_replace('/\s(?!src)[a-zA-Z]+=[\'\"]{1}[^\'\"]+[\'\"]{1}/iu',' $str);

上面的实例代码是过滤掉除了src属性外的所有标签属性.

过滤设置过滤除了alt和src之外的所有属性

代码如下:

$str = preg_replace('/\s(?!(src|alt))[a-zA-Z]+=[^\s]*/iu',' ', $str);

过滤所有html标签的属性的正则表达式:

$str = preg_replace("/<([a-z]+)[^>]*>/i","",$str );

只过滤alt属性的正则表达式:

(\s)alt=[^\s]*

过滤所有html标签的属性的正则表达式:

  1. $search = array ("'<script[^>]*?>.*?</script>'si"// 去掉 javascript 
  2. "'<[\/\!]*?[^<>]*?>'si"// 去掉 HTML 标记 
  3. "'([\r\n])[\s]+'"// 去掉空白字符 
  4. "'&(quot|#34);'i"// 替换 HTML 实体 
  5. "'&(amp|#38);'i"
  6. "'&(lt|#60);'i"
  7. "'&(gt|#62);'i"
  8. "'&(nbsp|#160);'i" 
  9. ); // 作为 PHP 代码运行 
  10. $replace = array ("","","\\1","\"","&","<",">"," "); 
  11. $html = preg_replace($search$replace$html);

Tags: 过滤html标签 PHP正则DEMO

分享到: