Asp.net中防刷新重複提交、防後退方法

 Asp.net中防刷新重複提交、防後退方法
簡單操作方法防後退和刷新
Page_Load中加入

   Response.Cache.SetNoStore();

   //Session中存儲的變量“IsSubmit”是標記是否提交成功的
   if (!IsPostBack)
    if (Session["IsSubmit"]==null)
     Session.Add("IsSubmit",false);
   if ((bool)Session["IsSubmit"])

   {

    //如果表單數據提交成功,就設“Session["IsSubmit"]”爲false

    Session["IsSubmit"] = false;

    //顯示提交成功信息

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

   }
   else

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

    TextBox1.Text = "";
    Response.End();
   }
提交按鈕中加入
Session["IsSubmit"] = true;
Response.Redirect ("本頁");


網頁防刷新重複提交、防後退解決方法

提交後禁用提交按鈕(大部分人都是這樣做的)

如果客戶提交後,按F5刷新怎麼辦?

使用Session

在提交的頁面也就是數據庫處理之前:

if session("ok")=true then
   response.write "錯誤,正在提交"
   response.end
end if

數據處理完後,修改session("ok")=false。

數據處理成功馬上Redirect到另外一個頁面

操作後刷新的確是個問題,你可以使用跳轉頁面、關閉本頁面,如果是有參數據條件來控制的,那就應該好做了,可以直接修改window.location的值,把參數全部改掉,這樣就差不多了。

缺點:簡單地運用Response.Redirect將不再有效,因爲用戶從一個頁面轉到另一個頁面,我們都必須用客戶端代碼清除location.history。注意,這種方法清除的是最後一個訪問歷史記錄,而不是全部的訪問記錄。 點擊後退按鈕,再點擊後退按鈕,你可以看到這時打開的是本頁面之前的頁面!(當然,這是在你的客戶端啓用了JavaScript功能的條件下。)

如果客戶按後退,怎麼辦?

防止網頁後退--禁止緩存

我們在進行數據庫添加操作的時候,如果允許後退,而正巧有刷新了頁面,就會再次執行添加操作,無疑這不是我們需要的,像一般網上很多禁止緩存的代碼,有時並不可靠,這時你只要在操作的頁面加上就可以了,在網頁的裏指定要定向的新頁,再點後退,看是不是不會再退到剛纔的操作頁面了,實際上已經把這個歷史給刪除了

ASP:
Response.Buffer = True   
Response.ExpiresAbsolute = Now() - 1   
Response.Expires = 0   
Response.CacheControl = "no-cache"

ASP.NET:
Response.Buffer=true;
Response.ExpiresAbsolute=DateTime.Now.AddSeconds(-1);
Response.Expires=0;
Response.CacheControl="no-cache";

究竟怎樣才能"禁用"瀏覽器的後退按鈕?或者“怎樣才能防止用戶點擊後退按鈕返回以前瀏覽過的頁面?”

遺憾的是,我們無法禁用瀏覽器的後退按鈕。

防止網頁後退--新開窗口

用window.open彈出表單頁面,點提交後關閉該頁;處理提交的ASP頁也是用彈出,設定表單的target,點提交時window.open("XXX.asp","_blank"),然後用JS來提交表單,完成後window.close();
簡單的說,就是提交表單的時候彈出新窗口,關閉本窗口。對於window.open()打開的窗口怎麼後退?能後退到哪裏去?

 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章