防止表单重复提交的几种方法总结

 

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Warpar/article/details/72917924

1、JavaScript防止表单重复提交(主要用于网络延迟情况下用户点击多次submit按钮导致表单重复提交)

在jsp页面中,添加JavaScript代码来防止表单的重复提交。主要是针对在网络延迟情况下用户有时间点击多次submit按钮导致表单重复提交,使用javascript控制Form表单只能提交一次。

<script type=”text/javascript”>

Var isCommitted = false;  //表单是否应提交标识,默认为false

function dosubmit() {

If(isCommitted == false){ //提交表单后,将表单是否已经提交设置为true

isCommitted = true; //返回true让表单正常提交

return true;

}else{

return false; //返回false表单不提交

}

}

</script>

2、将提交按钮设置为不可用,让用户点击第一次提交之后,没有机会点击第二次提交按钮的机会。(也可以将提交按钮隐藏起来,在点击第一次之后,将提交按钮隐藏起来)

function dosubmit() {

//获取表单提交按钮

Var btnSubmit = documen.getElementById(“sumit”);

//将表单提交按钮设置为不可用,可以避免用户再次点击提交按钮进行提交

btnSubmit.disabled = “disabled”;

//返回true让表单可以提交

return true;

}

3、利用Session防止表单重复提交(主要用于表单提交之后,点击浏览器刷新按钮导致表单重复提交,以及点击浏览器返回按钮退回到表单页面后进行再次提交)

(1)、表单页面由servlet程序(服务器端)生成,servlet为每次产生的表单页面分配一个唯一的随机标识号(Token令牌),并在FORM表单的一个隐藏字段中设置这个标识号,同时在当前用户的Session域中保存这个标识号。
(2)、当用户提交FORM表单时,负责处理表单提交的serlvet得到表单提交的标识号,并与session中存储的标识号比较,如果相同则处理表单提交,处理完后清除当前用户的Session域中存储的标识号。如果不一致,就是重复提交了,此时服务器端就可以不处理重复提交的表单了。
(3)、服务器程序将拒绝用户提交的表单请求情况如下:
1):存储Session域中的表单唯一的标识号与表单提交的标识号不同
2):当前用户的Session中不存在表单标识号
3):用户提交的表单数据中没有标识号字段

(4)、创建标识号

String token = TokenProccessor.getInstance().makeToken();

(5)、在服务器端使用Session保存标识号

request.getSession().setAttribute(“token”,token);

(6)、在form表单中也就是JSP页面中,使用隐藏域来存储标识号(Token令牌)

(可以使用EL表达式取出存储在Session域中的token)

<%--    

<input type=”hidden” name=”token” value=”<%=session.getAttribute(“token”) %>”>

--%>

猜你喜欢

转载自blog.csdn.net/weixin_42246997/article/details/82694790
今日推荐