当前位置:首页 >> 网络通讯 >> 网络安全 >> 内容

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

时间:2013/4/19 12:09:00 作者:平凡之路 来源:xuhantao.com 浏览:

如果用户表单输入一些内容,……特别是一些内容比较多的表单项,且无固定格式 ,如地址,文章内容……此时用户可以输入JS代码等来执行
 
STEP1:在设计方案上,输入项要尽可能检测格式并限制长度。要有服务端检测,不能依赖客户端检测。在数据库设计上要限制字段长度……
 
输出页面时需要进行HTML转码,如输出地址内容
 
<td ><%=convert.html(cus.getAddress())%></td >
 
 
 
public static String html(String content) {
 
if(content==null) return "";       
 
    String html = content;
 
      
 
html = html.replaceAll( "&", "&amp;"); // 替换&号
 
html = html.replace( "\"", "&quot;"); //" 替换双引号
 
html = html.replace( "\t", "&nbsp;&nbsp;");// 替换跳格
 
html = html.replace( " ", "&nbsp;");// 替换空格
 
html = html.replace("<", "&lt;");
 
html = html.replaceAll( ">", "&gt;");
 
    return html;
 
}
 

  
有些人是在入库的时候做HTML编码,www.xuhantao.com,这样与原意不付,应该在出库的时候转码,如果输出载体为HTML页面,则进行HTML转码……。如果是用户控件一类的,涛涛电脑知识网,就可以不做HTML转码了。
 
真正麻烦的是,在一些场合我们要允许用户输入HTML,又要过滤其中的脚本。Tidy 等HTML 清理库可以帮忙……本文不讨论这种情况 ……
 
STEP2: 检测
 
主要对用户输入内容在显示时的页面进行检测,照上面列个清单出来
 
STEP3:检测结果纪录表
 
STEP4: 根据检测结果做修复,在纪录表上记录修复结果
 
STEP5:复测,在纪录表上记录复测结果

摘自 attilax的专栏

相关文章
  • 没有相关文章
共有评论 0相关评论
发表我的评论
  • 大名:
  • 内容:
  • 徐汉涛(www.xuhantao.com) © 2024 版权所有 All Rights Reserved.
  • 部分内容来自网络,如有侵权请联系站长尽快处理 站长QQ:965898558(广告及站内业务受理) 网站备案号:蒙ICP备15000590号-1