- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于JavaWeb技术表单重复提交问题解决方案分析与应用
基于JavaWeb技术表单重复提交问题解决方案分析与应用
摘要:在基于B/S架构的JavaWeb项目开发中都会涉及到表单的重复提交问题,传统的解决方案与技术也很多,但大多都存在代码安全漏洞,不能从根本上解决表单的重复提交问题,该文作者针对这类问题,通过把JavaScript、Session会话、隐藏表单、Base64编码、Servlet,以及Struts2框架中的token令牌等技术进行综合应用,给出了一个解决表单重复提交问题的终极方案。
关键词:JavaWeb;表单重复提交;Session会话;Servlet;token令牌
中图分类号:TP311 文献标识码:A 文章编号:1009-3044(2013)35-7966-02
随着信息化和网络化技术的飞速发展,越来越多的企事业单位选择采用基于B/S架构的JavaWeb技术进行业务应用系统的研发。但在所有的项目开发中都会涉及到表单的重复提交问题,传统的解决方案主要是通过JavaScript技术、或使用一些页面框架技术,如FrameSet等、或通过对使用者隐藏路径等方式来规避这类问题,但这些技术都存在一定的安全漏洞,都不能从根本上解决表单的重复提交问题。该文通过开发某企业的人事管理系统中的部门管理模块中的部门添加功能实现,并解决表单重复提交问题为应用背景,分析了表单重复提交安全问题存在的原因,并给出了表单重复提交问题的终极解决方案的详细步骤。
1 表单重复提交安全问题存在原因分析
表单重复提交的安全隐患主要通过两种方式来体现,第一是通过快速连续多次单击或点击浏览器中的回退按钮再次单击提交部门添加页面中的按钮来实现,其二是通过刷新请求页面或手动输入部门添加页面请求的Servlet路径来实现。对于第一种方式,传统的解决方式是使用JavaScript代码把按钮设置成不可用,或弹出重复提交的对话框来实现,但使用者可以绕过JavaScript代码访问,所以这种方式还是不安全的,对于第二种方式传统的解决方式是通过使用一些页面框架,并隐藏提交表单的路径来达到防止重复提交,实验证明这也是不安全的。
2 表单重复提交问题解决方案实现
该方案的思想是在添加部门页面的表单中增加一个隐藏字段token,该字段的值是通过Java脚本代码产生一个随机数,为了该随机数???绝对安全,我们可以通过一个工具类来获得一个随机数,并对随机数进行MD5加密,为了生成随机数的可读性我们再对加密的字符使用Base64算法进行明文转换,并把该随机数设置到Session会话域中,在对应的提交请求Servlet类中进行隐藏字段值和Session域中值的获取与比较,分析该次请求是否来自重复提交,如果是则给出相应的处理代码逻辑与显示页面,同时在Servlet处理逻辑完成前一定要把Session域中的token令牌值移除掉。具体实现步骤如下。
1) 随机数令牌值产生器工具类代码
public class TokenProccessor {
// 负责产生令牌 保证唯一 单例
private TokenProccessor(){}
private static TokenProccessor instance = new TokenProccessor();
public static TokenProccessor getInstance() {
return instance;}
// 设计一个方法产生令牌
public String makeToken() {
// 1. 产生一个随机数
String random =new Random().nextInt+ System.currentTimeMillis() +;
// 2.采用 md5进行加密
MessageDigest msgdegest = MessageDigest.getInstance(md5);
byte[] md5 = msgdegest.digest(random.getBytes());
// 3. 采用base64 算法转换明文
BASE64Encoder encoder = new BASE64Encoder();
String token = encoder.encode(md5);
return token;
}}
2) 部门添加页面核心代码
…
3) 请求处理Servlet类RegisterServlet的核心代码
// 判断是否为重复提交
// 获得提交的token
String token =
您可能关注的文档
最近下载
- 秋季安全生产培训ppt.pptx VIP
- (完整word版)护理安全(不良)事件报告制度及工作流程.docx VIP
- 体育教学工作总结学情分析报告(共8).docx VIP
- 内部审核工作程序.pdf VIP
- 怪物猎人3金手指素材代码.doc VIP
- 马工程-中国古代文学史(第二版)第三编上册魏晋南北朝文学PPT课件-50109.docx VIP
- 传统节日中秋节介绍英文版ppt课件.pptx VIP
- 销售合同管理excel表格系统 台账登记统计 到期提醒Excel表格模板 (9).xlsx VIP
- 刘毅5000词汇.doc VIP
- 《单相全桥逆变器死区效应分析及补偿方法》-毕业论文(设计).doc VIP
文档评论(0)