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

前端之家收集整理的这篇文章主要介绍了PHP正则表达式过滤html标签属性(DEMO)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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


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


@H_4030@例如


@H
403_0@<span style="color: #0000ff">

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


@H_403_0@<div class="codetitle"><a style="CURSOR: pointer" data="16503" class="copybut" id="copybut16503" onclick="doCopy('code16503')"> 代码如下:
<div class="codebody" id="code16503">
$str= preg_replace('/\s(?!src)[a-zA-Z]+=[\'\"]{1}[^\'\"]+[\'\"]{1}/iu',' $str);

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

@H_403_0@

属性

@H_403_0@代码如下:

@H_403_0@
代码如下:

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

@H_403_0@
代码如下:
]*>/i","",$str );

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

@H_403_0@
代码如下:

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

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

猜你在找的PHP相关文章