PHP正则表达式过滤html标签属性(DEMO)
过滤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 ("'<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);
相关阅读:jquery ajax结合thinkphp的getjson实现跨域的方法ThinkPHP使用心得分享-分页类Page的用法如何调试异步加载页面里包含的js文件JavaScript编程中实现对象封装特性的实例讲解JavaScript获取图片像素颜色并转换为box-shadow显示QuiteRSS: Linux桌面的RSS阅读器 你值得拥有C#数据绑定(DataBinding)简单实现方法css教程制作css圆角边框(兼容全部浏览器)如何解决PHP使用mysql_query查询超大结果集超内存问题jQuery插件开发的两种方法及$.fn.extend的详解 win10耳机有电流声而且声音很大影响使用该怎么办?如何解决JQuery ajaxSubmit提交中文乱码Win10 Mobile Build 10549正式推送:须回滚到WP8.1升级Asp.net把图片存入数据库和读取图片的方法