PHP正则表达式过滤html标签属性的方法-创新互联

这篇文章主要讲解了“PHP正则表达式过滤html标签属性的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“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标签的属性的正则表达式:

复制代码 代码如下:


$search = array ("']*?>.*?'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正则表达式过滤html标签属性的方法”的内容了,经过本文的学习后,相信大家对PHP正则表达式过滤html标签属性的方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联网站建设公司,,小编将为大家推送更多相关知识点的文章,欢迎关注!


当前题目:PHP正则表达式过滤html标签属性的方法-创新互联
文章转载:http://pwwzsj.com/article/ghidg.html