您的位置:首页 > 其它

XSS跨站点脚本攻击解决方案

2012-06-05 10:27 204 查看
XSS跨站点脚本攻击解决方案

如果用户表单输入一些内容,……特别是一些内容比较多的表单项,且无固定格式,如地址,文章内容……此时用户可以输入JS代码等来执行

STEP1:在设计方案上,输入项要尽可能检测格式并限制长度。要有服务端检测,不能依赖客户端检测。在数据库设计上要限制字段长度……

输出页面时需要进行HTML转码,如输出地址内容

<td><%=convert.html(cus.getAddress())%></td>



publicstaticStringhtml(Stringcontent){

if(content==null)return"";

Stringhtml=content;



html=html.replaceAll("&","&");//替换&号

html=html.replace("\"",""");//"替换双引号

html=html.replace("\t","  ");//替换跳格

html=html.replace(""," ");//替换空格

html=html.replace("<","<");

html=html.replaceAll(">",">");

returnhtml;

}




有些人是在入库的时候做HTML编码,这样与原意不付,应该在出库的时候转码,如果输出载体为HTML页面,则进行HTML转码……。如果是用户控件一类的,就可以不做HTML转码了。

真正麻烦的是,在一些场合我们要允许用户输入HTML,又要过滤其中的脚本。Tidy等HTML清理库可以帮忙……本文不讨论这种情况……

STEP2:检测

主要对用户输入内容在显示时的页面进行检测,照上面列个清单出来

STEP3:检测结果纪录表

STEP4:根据检测结果做修复,在纪录表上记录修复结果

STEP5:复测,在纪录表上记录复测结果
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: