关于from单重复刷新提交问题.doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
关于from单重复刷新提交问题

关于from表单重复提交 (一) 介绍两种防止重复提交的方法: 1.?Jsp页面提交 2.?struts的action提交 第一类:Jsp页面提交:在Jsp页面中设计状态位,这样的话,改变状态位就不能进行提交操作。 script language=javascript? ??? var checkSubmitFlg = false;??? ??? function checkSubmit() {????? ??????? if (!checkSubmitFlg) {? ??????? checkSubmitFlg = true;????? ??????? return true;?? ??????? }else{ ???????? alert(不能重复提交); ???????? return false; ??????? } ???? } /script form action=XXXX method=POST?onsubmit=return??checkSubmit() ? 内容:input type=text name=content value=/br ? input type=submit value=提交br /form ? 此类做法类似的还有:提交时将submit标签设置为不可操作,或者当点了提交按钮后使按钮不可用,或者在页面加个验证码,如果验证不通过就不跳转! ? 第二类:Struts的action提交:struts2的防止重复提交,使用到了token(令牌机制),并且使用到了struts2的token拦截器。 添加商品页面Jsp代码: HYPERLINK /blog/819559 \o 复制代码 body ? s:form action=product_doAddProduct.action method=post ??? s:token/s:token ??? s:textfield name=name label=商品名称/s:textfield ??? s:textfield name=price label=商品价格/s:textfield ??? s:submit value=提交/s:submit ? /s:form /body struts.xml 配置文件: package name=token extends=struts-default namespace=/jsp ???? action name=product class=org.cric.action.ProductAction ?????? result name=success/jsp/product.jsp/result ?????? result name=invalid.token/jsp/error.jsp?message=重复提交/result ?????? interceptor-ref name=token/ ?????? interceptor-ref name=defaultStack/ ???? /action ?/package 动作层Java代码: public String doAddProduct() throws Exception{ ??? System.out.println(添加商品了……); ??? Thread.sleep(10000); ??? return success; ? } 错误页面Html代码: body ${param[message]} /body 显示商品信息Html页面代码: body ? 商品名称:s:property value=%{name}/br ? 商品价格:s:property value=%{price}/ /body 注意: a:当拦截器拦截到重复提交的action时候,会跳转到invalid.token指定的页面。 b:为了使用同一的错误页面,在错误页面上接受到message参数的值,可以在error.jsp使用 ${param[message]}。 c:在提交页面的form中添加s:token/标签,需要在页面中加上。 ? token-session拦截器: Token Session拦截器扩展了Token并提供了一种更复杂的服务。Token Session拦截器不想Token拦截器那样会返回一种特殊的结果并添加一个动作错误,它采用的做法只是阻断后续的提交,而这么做的后果是用户将看到同一的响应,就好像只有一次提交那样! ? Xml代码 HYPERLINK /blog/819559 \o 复制代码 ? package action name=product class=org.cric.action.Product

文档评论(0)

dmdt5055 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档