找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 852|回复: 0
打印 上一主题 下一主题

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

[复制链接]

2500

主题

2513

帖子

7520

积分

论坛元老

Rank: 8Rank: 8

积分
7520
跳转到指定楼层
楼主
发表于 2018-2-14 05:36:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            过滤html标签在php中可以有内置的函数了,但它过滤的太干净了,我们就整理了一下些利用正则来过滤指定html标签的例子,具体如下所示。
采集的时候有时候需要过滤掉多余的标签属性,比如 img标签过滤掉除了src属性之外的所有属性例如删除titile alt等属性以及一些脚的onclick属性等。
例如
过滤除了src之外的所有属性:
[U]复制代码[/U] 代码如下:
$str= preg_replace('/\s(?!src)[a-zA-Z]+=[\'\"]{1}[^\'\"]+[\'\"]{1}/iu',' $str);
上面的实例代码是过滤掉除了src属性外的所有标签属性.
过滤设置过滤除了alt和src之外的所有属性
代码如下:
[U]复制代码[/U] 代码如下:
$str = preg_replace('/\s(?!(src|alt))[a-zA-Z]+=[^\s]*/iu',' ', $str);
过滤所有html标签的属性的正则表达式:
[U]复制代码[/U] 代码如下:
$str = preg_replace("/]*>/i","",$str );
只过滤alt属性的正则表达式:
[U]复制代码[/U] 代码如下:
(\s)alt=[^\s]*
过滤所有html标签的属性的正则表达式:
[U]复制代码[/U] 代码如下:
$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正则表达式完全教程之精华篇
  • php获取超链接文本内容的正则表达式(五种方法)
  • 非常重要的php正则表达式详解
  • php正则表达式中贪婪与非贪婪介绍
  • php正则表达式验证(邮件地址、Url地址、电话号码、邮政编码)
  • PHP正则表达式入门教程(推荐)
  • PHP正则表达式抓取某个标签的特定属性值的方法
  • Ajax和PHP正则表达式验证表单及验证码
  • php使用正则表达式获取字符串中的URL
  • 史上最全的PHP正则表达式(手机号需要加上177-***)
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端