在线过滤器html,过滤html在线编辑器产生有危害代码

部分强大的在线编辑器,已经包含了代码整理,过滤功能,但js处理的能被很轻易的饶过,服务端必须要再次过滤一次,这几天花了点时间,写了部分,希望对大家有点用处,本人能力有限,还请有能力的朋友补全它。

/*不需要过滤的数组*/

$htm_on=array(

"",

"",

"",

"

",

"",

"",

"",

"",

"",

"",

"",

"",

"font");

$htm_on_uper=array(

"",

"",

"",

"

",

"",

"",

"",

"",

"",

"",

"",

"",

"FONT");

/*字符格式*/

$str=strtolower($str);

$str=preg_replace("//s+/", " ", $str);//过滤回车

$str=preg_replace("/ +/", " ", $str);//过滤多个空格

/*过滤/替换几种形式的js*/

$str=preg_replace("/(.*?)/si","",$str);//删除格式,

//$str=preg_replace("/(.*?)/si","/1>//2/3>",$str);//替换为可以显示的,

$str=preg_replace("//si","",$str);//删除

//$str=preg_replace("/<(script.*?)>/si","/1>",$str);//替换未封闭

/*删除/替换表单*/

$str=preg_replace("/<(//?form.*?)>/si","",$str);//删除表单

//$str=preg_replace("/<(//?form.*?)>/si","/1>",$str);//替换表单

$str=preg_replace("/<(i?frame.*?)>(.*?)<(//i?frame.*?)>/si","",$str);//删除框架

//$str=preg_replace("/<(i?frame.*?)>(.*?)<(//i?frame.*?)>/si","/1>//2/3>",$str);//替换框架

/*过滤on事件*/

$str=preg_replace("/href=(.+?)([/"|/'| |>])/ie","'href='.strtoupper('//1').'//2'",$str);//把href=涉及到的on转换为大写。

$str=str_replace($htm_on,$htm_on_uper,$str);//把换为大写,dhtml标签字符,正则判断太烦琐,采用转换办法。

$str=preg_replace("/(on[^ /.<>]+?)([ |>])/s","//2",$str);//取掉on事件

/*过滤超级连接的js*/

$str=preg_replace("/(href|src|background|url|dynsrc|expression|codebase)[=:/(]([ /"/']*?/w+/..*?|javascript|vbscript:[^>]*?)(/)?)([ >//])/si","//1='#' //3//4",$str);//取掉href=javascript:

//返回小写字符

$str=strtolower($str);

$str=str_replace("&","&",$str);

以上就是过滤html在线编辑器产生有危害代码 的详细内容,更多请关注php中文网其它相关文章!

article_wechat2021.jpg?1111

声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值