• ASP.Net中防止页面刷新重复提交的几种方法


    【摘要】

    目前很多网站都要提交页面插入或更新数据库,比如留言本,一个用户提交留言后,如果按F5,就会重新提交一遍留言,导致数据库出现两条一模一样的留言,
    本文介绍了几种防止页面刷新,导致重复提交数据的方法。

    本站原创,转载请注明: http://beinet.cn/blog/


    【全文】

    1、也是最简单和最常用的办法,就是使用转向页面语句,分两种:
        a.使用服务器端的 Response.Redirect("YourPage");
        b.使用客户端脚本 <script language=javascript>location.href='yourPage';</script>
        这两种方法的缺点是如果要保留页面数据不太方便,如果不用保留可以采用。

    2、操作完毕设置一个Session,进入页面时判断这个Session是否为null,如果不是表示已经提交过了,但是缺点就是这个页面无法再提交了,必须在别的页面清空这个Session。

    3、是从网上搜索到的一种方案,学习并共享一下:
    DetectRefresh.aspx  
      ===========================       
      <%@   Page   Inherits="StevenBey.Web.UI.Page"   %>  
      <html>  
      <head>  
      <title>Detecting   Page   Refresh   [Demo]</title>  
      </head>  
      <body>  
      <form   runat="server">  
      <asp:button   Text="Test   Refresh"   runat="server"   />  
      </form>  
      IsRefresh   =   <%=   IsRefresh   %>  
      </body>  
      </html>  

    StevenBey.Web.UI.Page.cs  
      ======================  
      namespace   StevenBey.Web.UI  
      {  
      public   class   Page   :   System.Web.UI.Page  
      {  
        private   bool   _refreshState;  
        private   bool   _isRefresh;  
       
        public   bool   IsRefresh  
        {  
          get  
          {  
          return   _isRefresh;  
          }  
        }  
       
        protected   override   void   LoadViewState(object   savedState)  
        {  
          object[]   allStates   =   (object[])   savedState;  
          base.LoadViewState(allStates[0]);  
          _refreshState   =   (bool)   allStates[1];  
          _isRefresh   =   _refreshState   ==   (bool)   Session["__ISREFRESH"];  
        }  
       
        protected   override   object   SaveViewState()  
        {  
          Session["__ISREFRESH"]   =   _refreshState;  
          object[]   allStates   =   new   object[2];  
          allStates[0]   =   base.SaveViewState();  
          allStates[1]   =   !_refreshState;  
          return   allStates;  
        }  
      }  
      }

     
  • 相关阅读:
    Codeforces Round #271 (Div. 2) F. Ant colony 线段树
    poj 1744 tree 树分治
    HDU Shell Necklace CDQ分治+FFT
    BZOJ 1567: [JSOI2008]Blue Mary的战役地图 矩阵二维hash
    BZOJ 1042: [HAOI2008]硬币购物 容斥+背包
    HDU 6078 Wavel Sequence 树状数组优化DP
    Gym
    HDU 6058 Kanade's sum 二分,链表
    HDU 6061 RXD and functions NTT
    ZOJ 3233 Lucky Number 容斥原理
  • 原文地址:https://www.cnblogs.com/chenzhao/p/2082084.html
Copyright © 2020-2023  润新知