首页 > 语言 > PHP > 正文

php正则表达式过滤html标签属性

2024-09-04 11:47:38
字体:
来源:转载
供稿:网友

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

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

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

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

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

过滤设置过滤除了alt和src之外的所有属性,代码如下:

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

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

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

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

  1. (/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); 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表