网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网页制作 > 心得技巧
网页制作:Dreamweaver教程,FrontPages教程,Javascript教程,HTML教程,CSS教程,心得技巧,DHTML教程,网页特效,Discuz!论坛
本月文章推荐
.熟练设计师的七原则(2):颜色运用.
.DIV下图片自适应解决方法.
.谈谈网站速度的优化技巧.
.震撼 Google所见即所得页面编辑器.
.网页设计统计报告:五年以来网页.
.网页中时间和日期的各种格式的特.
.入门指导:制作网页必须注意的几.
.过来人谈如何快速成为一名网页设.
.什么是静态网页和动态网页?.
.网页制作解惑:图象文件的路径.
.另一个角度谈谈DIV+CSS.
.图片左右循环连续滚动代码,解决.
.SSI技术—SHTML(生成静态时用的.
.谈谈xhtml的结构标签.
.使用开源软件Lilina构建RSS聚合器.
.教你制作GBK与Unicode的对照表.
.网页设计中的功能与美化.
.渐飞CMS普及风暴活动公告.
.Blogger Hack:Meta Data优化.
.经典收藏:网页页面常用的特殊符.

正则表达式过滤HTML危险脚本

发表日期:2006-9-2


在做一些网站(特别是bbs之类)时,经常会有充许用户输入html样式代码,却禁止脚本的运行的需求, 以达到丰富网页样式,禁止恶意代码的运行。
当然不能用 htmlencode 和 htmldecode 方法,因为这样连基本的html代码会被禁止掉。
我在网上搜索,也没有找到好的解决办法,倒是收集了一些脚本攻击的实例:
1. <script>标记中包含的代码
2. <a href=javascript:...中的代码
3. 其它基本控件的 on...事件中的代码
4. iframe 和 frameset 中载入其它页面造成的攻击
有了这些资料后,事情就简单多了,写一个简单的方法,用正则表达式把以上符合几点的代码替换掉:
public string wipescript(string html)
{
system.text.regularexpressions.regex regex1 = new system.text.regularexpressions.regex(@"<script[\s\s]+</script *>",system.text.regularexpressions.regexoptions.ignorecase);
system.text.regularexpressions.regex regex2 = new system.text.regularexpressions.regex(@" href *= *[\s\s]*script *:",system.text.regularexpressions.regexoptions.ignorecase);
system.text.regularexpressions.regex regex3 = new system.text.regularexpressions.regex(@" on[\s\s]*=",system.text.regularexpressions.regexoptions.ignorecase);
system.text.regularexpressions.regex regex4 = new system.text.regularexpressions.regex(@"<iframe[\s\s]+</iframe *>",system.text.regularexpressions.regexoptions.ignorecase);
system.text.regularexpressions.regex regex5 = new system.text.regularexpressions.regex(@"<frameset[\s\s]+</frameset *>",system.text.regularexpressions.regexoptions.ignorecase);
html = regex1.replace(html, ""); //过滤<script></script>标记
html = regex2.replace(html, ""); //过滤href=javascript: (<a>) 属性
html = regex3.replace(html, " _disibledevent="); //过滤其它控件的on...事件
html = regex4.replace(html, ""); //过滤iframe
html = regex5.replace(html, ""); //过滤frameset
return html;
}
此方法输入可能包含脚本的html代码,返回则就是干净的代码了。
http://www.cnblogs.com/skylaugh/archive/2006/09/01/492476.html
上一篇:正则表达式语法 人气:6625
下一篇:获得网页控件方法大全 人气:9071
浏览全部正则表达式的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐