过滤html标签在php中可以有内置的函数了,但它过滤的太干净了,我们就整理了一下些利用正则来过滤指定html标签的例子,具体如下所示。
采集的时候有时候需要过滤掉多余的标签属性,比如 img标签过滤掉除了src属性之外的所有属性例如删除titile alt等属性以及一些脚的onclick属性等。
例如
过滤除了src之外的所有属性:
复制代码 代码如下:
$str= preg_replace('/\\s(?!src)[a-zA-Z]+=[\\'\\"]{1}[^\\'\\"]+[\\'\\"]{1}/iu',' $str);
$str= preg_replace('/\\s(?!src)[a-zA-Z]+=[\\'\\"]{1}[^\\'\\"]+[\\'\\"]{1}/iu',' $str);
上面的实例代码是过滤掉除了src属性外的所有标签属性.
代码如下:
复制代码 代码如下:
$str = preg_replace('/\\s(?!(src|alt))[a-zA-Z]+=[^\\s]*/iu',' ', $str);
$str = preg_replace('/\\s(?!(src|alt))[a-zA-Z]+=[^\\s]*/iu',' ', $str);
复制代码 代码如下:
$str = preg_replace("/<([a-z]+)[^>]*>/i","",$str );
$str = preg_replace("/<([a-z]+)[^>]*>/i","",$str );
复制代码 代码如下:
(\\s)alt=[^\\s]*
(\\s)alt=[^\\s]*
复制代码 代码如下:
$search = array ("'<script[^>]*?>.*?</script>'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);
$search = array ("'<script[^>]*?>.*?</script>'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);
相关文章
猜你喜欢
- 个人服务器网站搭建:如何选择合适的服务器提供商? 2025-06-10
- ASP.NET自助建站系统中如何实现多语言支持? 2025-06-10
- 64M VPS建站:如何选择最适合的网站建设平台? 2025-06-10
- ASP.NET本地开发时常见的配置错误及解决方法? 2025-06-10
- ASP.NET自助建站系统的数据库备份与恢复操作指南 2025-06-10