首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Dotnet频道
中国IT教育
Google
首页 ASP.NET  C#  XML/WebService ADO.NET VC.NET VB.NET .NET 资讯动态 专题 RSS订阅 讨论 下载
您现在的位置: 中国IT实验室 >> Dotnet >> ASP.NET >> 正文

防止ASP.NET按钮多次提交的办法

        网上查了很多方法,都不太好使,不如自己写一个,思路就是把按钮按下时用Javascript在客户端把按钮下一次的onclick事件改为return false; 这样在服务器端页面重新送回客户端之前,再次点击按钮都不会Post到服务端。同时将按钮的style改为一行字的样子,光标也变成沙漏状。当服务端页面重新产生后Button又会回到初始状态。该方法对于F5刷新还不能防范,只是简单封闭了F5的按键,为了防止刷新时再次提交可以在页面返回前将一些TextBox控件清空,这样就可以判断如果该TextBox为空则不再进行后续操作(如写库)。 或是后台操作成功后跳转到另一个页面以防止恶意刷新。主要是考虑在企业内网使用,不是为了防黑客,所以不是非常严格。

         <html xmlns="http://www.w3.org/1999/xhtml">
        <head runat="server">
            <title>禁止多次提交网页测试</title>
            <style type="text/css">
            .disable
            {
                border-style:none;
                border-width: thin;
                background-color:Transparent;
                color: #CCCCCC;
                cursor:wait;
            }
            </style>
            <script type="text/javascript" language="javascript">
            function DisableButton()
            {
                document.getElementById("Button2").className  = "disable";
                document.getElementById("Button2").value = '正在提交.';
                document.getElementById("Button2").onclick=Function("return false;");
                return true;
            }
            document.onkeydown=mykeydown;
            function   mykeydown()
            {
                if(event.keyCode==116) //屏蔽F5刷新键
                {
                    window.event.keyCode=0;
                    return   false;
                }
            }
            </script>
        </head>
        <body>
            <form id="form1" runat="server">
            <div>
                输入一些内容<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
                <br />
                <asp:ListBox ID="ListBox1" runat="server" Height="77px" Width="332px">
            </asp:ListBox><br />
                <asp:Button ID="Button2" runat="server" Text="OK" Width="77px"
                    onclick="Button2_Click" />
            </div>
            </form>
        </body>
        </html>

[1] [2] 下一页

【责编:michael】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性…
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题…
 ·展现C#世界 C#程序设计专题…
 ·Java入门 Tomcat的配置技巧精华专题…
 ·Oracle RMAN物理备份技术详解…
 今日更新
 社区讨论
 博客论点
 频道精选
 Dotnet频道相关导航