主頁 > 知識(shí)庫 > Asp.Net防止刷新重復(fù)提交數(shù)據(jù)的辦法

Asp.Net防止刷新重復(fù)提交數(shù)據(jù)的辦法

熱門標(biāo)簽:Linux服務(wù)器 服務(wù)器配置 團(tuán)購網(wǎng)站 電子圍欄 銀行業(yè)務(wù) 科大訊飛語音識(shí)別系統(tǒng) 阿里云 Mysql連接數(shù)設(shè)置

在網(wǎng)上搜 一下,可以找到很多關(guān)于這方面的資料,其中有一篇是來自MSDN上的一種解決方法: http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnvs05/html/BedrockASPNET.asp 它是通過重新定義 System.Web.UI.Page 類來實(shí)現(xiàn)加載頁面時(shí),是“刷新”、“后退”請(qǐng)求,還是正常請(qǐng)求,其他的頁面則繼承了自定義的這 個(gè)Page類。感覺他這個(gè)方法比較獨(dú)特,有例子可以下載,有興趣的可以研究研究。

網(wǎng)上最多的解決此類問題的方法就是不保存緩存,即提交后表單上的數(shù)據(jù)不會(huì)被瀏覽器的緩存保存,如果此時(shí)再遇到刷新或者后退請(qǐng)求時(shí), 就會(huì)顯示“網(wǎng)頁已過期”,數(shù)據(jù)也就不會(huì)重復(fù)提交了,這就起到了阻止刷新重復(fù)提交的效果。

下面以簡單的提交一篇帖子為例,介紹禁用緩存防止刷新重復(fù)提交的方法,表單數(shù)據(jù)包括“標(biāo)題”和“正文”兩個(gè)部分。

以下是該方法的代碼(post.aspx):

復(fù)制代碼 代碼如下:

//頁面加載

protected void Page_Load(object sender, EventArgs e)

{

   //可以在頁面加載時(shí)設(shè)置頁面的緩存為“SetNoStore()”,即無緩存

   Response.Cache.SetNoStore();

   //Session中存儲(chǔ)的變量“IsSubmit”是標(biāo)記是否提交成功的

   if ((bool)Session["IsSubmit"])

   {

     //如果表單數(shù)據(jù)提交成功,就設(shè)“Session["IsSubmit"]”為false

     Session["IsSubmit"] = false;

     //顯示提交成功信息

     ShowMsg.Text = " * 提交成功!";

   }

   else

     //否則的話(沒有提交,或者是頁面刷新),不顯示任何信息

     ShowMsg.Text = "";

}

//提交按鈕(btnOK)單擊事件

protected void btnOK_Click(object sender, EventArgs e)

{

   if (txtTitle.Text.ToString().Trim() == "")

     //ShowMsg是用來顯示提示信息的

     ShowMsg.Text = " * 標(biāo)題不能為空!";

  else if (txtText.Text.ToString().Trim() == "")

     ShowMsg.Text = " * 內(nèi)容不能為空!";

  else

   {

     //這里是將數(shù)據(jù)提交到數(shù)據(jù)庫中,省略

     /*

     string sql = "insert into tab...values(...)";

     MyConn.ExecQuery(sql);

     */

     //提交成功后,設(shè)“Session["IsSubmit"]”為true

     Session["IsSubmit"] = true;

     //強(qiáng)制轉(zhuǎn)換頁面(不可少,否則刷新仍會(huì)重復(fù)提交,仍轉(zhuǎn)到本頁),

     通過頁面的轉(zhuǎn)換將緩存中的提交的數(shù)據(jù)都釋放了,即提交的標(biāo)單數(shù)據(jù)不會(huì)被保存到緩存里,

     如果后退的話,將會(huì)出現(xiàn)該頁無法顯示

     Response.Redirect("post.aspx");

  }

}


上面這個(gè)方法非常簡單也很實(shí)用,推薦大家使用。

下面是我自己研究出來的另一種方法,該方法不同于“不保存緩存的方法”,它是讓瀏覽器保存所有頁面緩存的。該方法通過隨機(jī)碼的方式 來判斷是正常提交還是“刷新”或“后退”的。

首先(提交頁面是post.aspx)在 Session 中 增加變量 Rnd 用來存放隨機(jī)碼,同時(shí)在提交表單數(shù)據(jù)時(shí)不做處理,而是讓頁面轉(zhuǎn)到 post.aspx?r=x,這里“x”等于Session["Rnd"],這個(gè)時(shí)候在頁面加載時(shí),通過判斷r的值和Session["Rnd"]的值是否相同,如果相同就處理提 交的數(shù)據(jù),否則即可認(rèn)為是“刷新”或者是“后退”操作了,最后再次付給Session["Rnd"]一個(gè)隨機(jī)碼。

以下是該方法代碼(post.aspx):

復(fù)制代碼 代碼如下:

//獲取隨機(jī)碼

public class MyRnd

{

   public static string Rnd()

   {

     //隨機(jī)碼是由 0-9 a-z A-Z 之間的數(shù)字或字母組成的

     //下面是生成的20位隨機(jī)碼

     //0..9 A..Z a..z

     //48-57 65-90 97-122

     string rst = "";

     Random rr = new Random();

     for (int i = 0; i 20; i++)

     {

       int ir = 0;

       do

       {

         ir = rr.Next(123);

         if((ir >= 48) (ir = 57)) break;

         else if((ir >= 65) (ir = 90)) break;

         else if ((ir >= 97) (ir = 122)) break;

       }

       while (true);

       rst += ((char)ir).ToString();

       }

     return rst;

   }

}

//頁面加載

protected void Page_Load(object sender, EventArgs e)

{

   //獲取URL中請(qǐng)求的“r”值,如果“r”不存在則 r=""

   string r = "";

   if(Request.QueryString["r"] != null)

     r = Request.QueryString["r"].ToString().Trim();

   string t;

   //獲取 “Session” 中的 “Rnd” 值,用于和“r”比較

   t = Session["Rnd"].ToString().Trim();

   //如果“r=t”則為提交操作,即可對(duì)表單的數(shù)據(jù)進(jìn)行處理

  if(r == t)

  {

     if (txtTitle.Text.ToString().Trim() == "")

       ShowMsg.Text = " * 標(biāo)題不能為空!";

     else if (txtText.Text.ToString().Trim() == "")

       ShowMsg.Text = " * 內(nèi)容不能為空!";

     else      {

       //這里是將數(shù)據(jù)提交到數(shù)據(jù)庫中,省略

       /*

       string sql = "insert into tab...values(...)";

       MyConn.ExecQuery(sql);

       */

       //提交成功后清空表單數(shù)據(jù)

       txtTitle.Text = "";

       txtText.Text = "";

       //顯示提交成功信息

       ShowMsg.Text = " * 提交成功!";

     }

  }

   //否則可以認(rèn)為是“刷新”或者“后退”操作

   else

   {

       txtTitle.Text = "";

       txtText.Text = "";

  }

  //最后要重新獲得“Session["Rnd"]”的值,并將“btnOK.PostBackUrl”設(shè)為“Session["Rnd"]”的值

  Session["Rnd"] = MyRnd.Rnd();

  btnOK.PostBackUrl ="post.aspx?r=" + Session["Rnd"].ToString().Trim();

}

//這里提交按鈕(btnOK)單擊事件就不需要寫任何代碼了


通過這種方法,每次加載頁面時(shí)“Session["Rnd"]”都將得到一個(gè)新的值,而在刷新或后退時(shí)就不會(huì)得到相同的“r”和“t”值,數(shù)據(jù)也就 不會(huì)被重復(fù)提交,只有通過“btnOK”來提交的操作才會(huì)得到“r==t”,數(shù)據(jù)才會(huì)被提交處理的,通過判斷隨機(jī)碼的方式來阻止刷新重復(fù)提交就 可以實(shí)現(xiàn)了。

您可能感興趣的文章:
  • ASP.NET中為GridView添加刪除提示框的方法
  • asp.net表單提交時(shí)防重復(fù)提交并執(zhí)行前臺(tái)的JS驗(yàn)證
  • asp.net防止刷新時(shí)重復(fù)提交(可禁用工具條刷新按鈕)
  • asp.net 處理F5刷新頁面重復(fù)提交頁面的一個(gè)思路
  • asp.net 防止用戶通過后退按鈕重復(fù)提交表單
  • Asp.Net中避免重復(fù)提交和彈出提示框的實(shí)例代碼

標(biāo)簽:棗莊 廣元 萍鄉(xiāng) 江蘇 衢州 大理 衡水 蚌埠

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Asp.Net防止刷新重復(fù)提交數(shù)據(jù)的辦法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266