来源:自学PHP网 时间:2015-04-17 14:11 作者: 阅读:次
[导读] 如果用户表单输入一些内容,特别是一些内容比较多的表单项,且无固定格式 ,如地址,文章内容此时用户可以输入JS代码等来执行STEP1:在设计方案上,输入项要尽可能检测格式并限制...
如果用户表单输入一些内容,……特别是一些内容比较多的表单项,且无固定格式 ,如地址,文章内容……此时用户可以输入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( "&", "&"); // www.2cto.com 替换&号 html = html.replace( "\"", """); //" 替换双引号 html = html.replace( "\t", " ");// 替换跳格 html = html.replace( " ", " ");// 替换空格 html = html.replace("<", "<"); html = html.replaceAll( ">", ">"); return html; } 有些人是在入库的时候做HTML编码,这样与原意不付,应该在出库的时候转码,如果输出载体为HTML页面,则进行HTML转码……。如果是用户控件一类的,就可以不做HTML转码了。 真正麻烦的是,在一些场合我们要允许用户输入HTML,又要过滤其中的脚本。Tidy 等HTML 清理库可以帮忙……本文不讨论这种情况 …… STEP2: 检测 主要对用户输入内容在显示时的页面进行检测,照上面列个清单出来 STEP3:检测结果纪录表 STEP4: 根据检测结果做修复,在纪录表上记录修复结果 STEP5:复测,在纪录表上记录复测结果 摘自 attilax的专栏 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com