防止重复提交的脚本。

原创 2007年09月21日 10:18:00

把这个作为 <-script src=.....js-><-/script-> 的形式Render到每个页面中就可以了。|
如果有PageBase,则在Init的时候用RegisterClientScriptBlock放上去更好。
因为客户没有抱怨过,所以也没有改进过。


function _doPostBack(){};
if(typeof("__doPostBack")=="function")
{
    _doPostBack=__doPostBack;
    __doPostBack=_doPostBackNew;
}

document.attachEvent("onmousemove",_onmousemove);
var _isPosting=false;
var _divMask=null;

function _onmousemove()
{
    if(_divMask)
    with(_divMask.runtimeStyle)
    {
        left=event.clientX+document.body.scrollLeft-4;
        top=event.clientY+document.body.scrollTop-4;
    }
}


function _makeMask()
{
    var div=document.createElement("DIV");
    with(div.runtimeStyle)
    {
        position="absolute";
        zIndex=999999;
        fontSize="1px";
        left=event.clientX+document.body.scrollLeft-4;
        top=event.clientY+document.body.scrollTop-4;
        width="8px";
        height="8px";
        cursor="wait";
       
        backgroundColor="gray";
        filter="alpha(opacity=10)";
    }
    try
    {
        document.body.insertAdjacentElement("BeforeEnd",div);
        div.onblur=new Function("this.focus()");
        div.focus();
    }
    catch(x){}
   
    if(_divMask)_divMask.removeNode(true);
    _divMask=div;
}

function _doPostBackNew(sender,args)
{
    if(_isPosting)
        return event.returnValue=!(event.cancelBubble=true);

    status="正在更新页面...";
    _doPostBack(sender,args);       
    _isPosting=true;
    _makeMask();
}

function _onformsubmit()
{
    if(_isPosting)
        return event.returnValue=!(event.cancelBubble=true);

    _isPosting=true;
    _makeMask();
}
new function _attachForms()
{
    with(new Enumerator(document.forms))
    for(;!atEnd();moveNext())
    {
        item().attachEvent("onsubmit",_onformsubmit);
        var div=document.createElement("div");
        div.runtimeStyle.width="0px";
        div.runtimeStyle.hight="0px";
        div.runtimeStyle.overflow="hidden";
        div.runtimeStyle.position="absolute";
        item(0).insertAdjacentElement("afterbegin",div);
        div.innerHTML="<INPUT TYPE=Submit name='webformpatchsubmitelement' onclick='return event.returnValue=false' id='webformpatchsubmitelement' value='webformpatchsubmitelement'/>";
    }
}

说说实际项目中如何防止重复提交

一般情况下,我们是允许点击浏览器的刷新按钮或者点击页面右键选择刷新的,不然微软做这个功能干啥,但在某些情况下可能这种刷新就会引发不少问题,原因就在于浏览器会缓存客户端最后一次的提交请求,比如我们发布一...
  • lsj19830812
  • lsj19830812
  • 2009年03月26日 21:03
  • 7330

spring mvc 防止重复提交表单的两种方法,推荐第二种

好的,下面来讲一下如何在Spring MVC里面解决此问题(其它框架也一样,逻辑一样,思想一样,和具体框架没什么关系)。要解决重复提交,有很多办法,比如说在提交完成后redirect一下,也可以用本文...
  • u013378306
  • u013378306
  • 2016年10月27日 12:56
  • 16038

JavaWeb 如何防止表单重复提交 - 使用Token,令牌

JavaWeb 如何防止表单重复提交 - 使用Token,令牌 说到重复提交 ,应该想到两种场景: 1. 在下单,或者支付 这种情况 那么不允许  刷新,不允许后退再点击提交。 2. 在填写表单之后,...
  • u011042188
  • u011042188
  • 2015年09月20日 14:29
  • 13897

防止表单重复提交的八种简单有效的策略

表单重复提交是在多用户Web应用中最常见、带来很多麻烦的一个问题。有很多的应用场景都会遇到重复提交问题,比如: 点击提交按钮两次。 点击刷新按钮。 使用浏览器后退按钮重复之前的操作,导致重复...
  • myhuashengmi
  • myhuashengmi
  • 2016年09月28日 21:25
  • 34924

防止重复提交的前后台实现

在日常生活中,网速不好的时候,经常出现提交表单后网页没有跳转或一直在跳转中,这时可能急性子的用户就会不停地按提交按钮,导致重复提交。重复提交会加重服务器压力。今天我们就来讨论下怎么防止重复提交···...
  • wws199304
  • wws199304
  • 2015年03月15日 19:19
  • 3427

javaweb开发之防止重复提交

防止重复提交 一、产生表单重复提交可能的情况 1. 由于服务器缓慢或网络延迟等原因,导致用户重复点击提交按钮。 2. 使用forward方式已经提交成功,再次刷新成功页面导致重复提交...
  • u012618337
  • u012618337
  • 2016年02月24日 14:59
  • 1242

防止数据恶意重复提交的方法

如何防止数据重复提交
  • lvqingyao520
  • lvqingyao520
  • 2016年10月30日 20:59
  • 2621

php 防止POST重复提交最简单方法

用隐藏域来做: 提交页面代码: " /> 目标页面(后台处理页面)代码: if($_SESSION['SUB']==$_POST['sub_rand']){echo 'aler...
  • k8080880
  • k8080880
  • 2015年08月17日 09:10
  • 3931

Struts1防止页面重复提交解决方案

转自:http://blog.csdn.net/lfsf802/article/details/8688536
  • u013953289
  • u013953289
  • 2014年09月30日 14:08
  • 549

防止发生ajax重复提交的情况

防止重复发送 Ajax 请求的解决方案 2016-01-05 分类:前端 阅读(5417) 评论(3)  本站采用[知识共享署名-非商业性使用-相同方式共享 许可协议]进行许可,转载请在正文明...
  • u010708759
  • u010708759
  • 2017年09月06日 11:29
  • 224
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:防止重复提交的脚本。
举报原因:
原因补充:

(最多只允许输入30个字)