ASP.NET防止重复提交

  第一种:

  在Button按钮中加入:

 

OnClientClick="this.disabled=true;this.form.submit();" UseSubmitBehavior="False"

 

  第二种: 

 Response.Redirect("Default.aspx");
        Response.Write("location.href='Default.aspx'?id=111");

 

 

第三种:

   方法的原理就是在每次处理请求(比如按钮的回发事件)后,都随机生成一个字符串,这个字符串分别存放在Session和响应页面中,在开始处理用户请求时,判断传上来的字符串和Session中的字符串是否匹配,如果是重复提交,客户端传上来的字符串就是个旧的(表单隐藏域里面的值是旧),显然和Session中的字符串不同。


也可以自定义一个控件方便调用。
具体步骤如下:


1、在进入页面的时候,随机生成个字符串,这个保存到session并且写到页面的控件上。


2、在提交后,判断你的session中的字符串和提交上来的字符串是否相同,相同就进行处理;不相同说明是重复提交,不进行相关处理,写个alert提醒不能重复提交。


3、然后重复第1步。
下面是测试页面的源代码。

 

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="test.aspx.cs" Inherits="test" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
     <title>test</title>
</head>
<body>
     <form id="form1" runat="server">
         <div>
             <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="Button" />
             <asp:HiddenField ID="HidSign" runat="server" />
         </div>
     </form>
</body>
</html>

 

public partial class test : System.Web.UI.Page
{
     protected void Page_Load(object sender, EventArgs e)
     {
         if (!IsPostBack)
         {
             UpdateSign();
         }
     }
     protected void Button1_Click(object sender, EventArgs e)
     {
         if (Session["HidSign"].ToString() == HidSign.Value)
         {
             this.ClientScript.RegisterStartupScript(this.GetType(), "startup", "alert('更新成功!')", true);
             UpdateSign();
         }
         else
         {
             this.ClientScript.RegisterStartupScript(this.GetType(), "startup", "alert('请勿重复提交!');", true);
             UpdateSign();
         }
   }
     private void UpdateSign()
     {
         HidSign.Value = DateTime.Now.ToString("ffffff");
         Session["HidSign"] = HidSign.Value;
     }
}

  
如果觉得session耗资源,也可以声明全局的静态变量,用他替换session

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值