做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

ASP.NET中防止頁面刷新造成表單重復提交執行兩次操作

來源:懂視網 責編:小采 時間:2020-11-27 22:37:54
文檔

ASP.NET中防止頁面刷新造成表單重復提交執行兩次操作

ASP.NET中防止頁面刷新造成表單重復提交執行兩次操作:之前看過別人防刷新的方法,是讓頁面刷新或返回上一步讓頁面過期,這里介紹一種另類的方法,使用Session來處理。 實現原理: 由于刷新提交表單,實際上提交的就是上一次正常提交的表單,所以我們只要做一個標志,判斷出是新表單還是上一次的舊表單就可以分辨
推薦度:
導讀ASP.NET中防止頁面刷新造成表單重復提交執行兩次操作:之前看過別人防刷新的方法,是讓頁面刷新或返回上一步讓頁面過期,這里介紹一種另類的方法,使用Session來處理。 實現原理: 由于刷新提交表單,實際上提交的就是上一次正常提交的表單,所以我們只要做一個標志,判斷出是新表單還是上一次的舊表單就可以分辨

之前看過別人防刷新的方法,是讓頁面刷新或返回上一步讓頁面過期,這里介紹一種另類的方法,使用Session來處理。

實現原理:

由于刷新提交表單,實際上提交的就是上一次正常提交的表單,所以我們只要做一個標志,判斷出是新表單還是上一次的舊表單就可以分辨出是否進行了重復提交操作。

實現方法:

在頁面上放置一個Hidden域,當頁面第一次載入的時候,在Session里面保存一個標志,同時,把這個標志保存到頁面上的Hidden里面。在提交表單時,判斷表單中提交上來的Hidden和Session中的標志是否一致,就可以知道是正常的提交表單,還是刷新頁面導致的重復提交。需要注意的是,在每次提交表單的處理之后,要更新Session里面的標志。

代碼實例:代碼很少,首先是頁面上。

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="Test.Web.Default" %>

<!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 id="Head1" runat="server">
 <title></title>
</head>
<body>
 <form id="form1" runat="server">
 <div>
 <input type="text" id="tbxName" runat="server" />
 <input type="text" id="tbxPass" value="" runat="server" />
 <asp:Button ID="btnSubmit" runat="server" OnClick="Button1_Click" Text="Button" />
 <asp:Label ID="lblMessage" runat="server" Text=""></asp:Label>
 <input id="hiddenTest" type="hidden" value="<%= GetToken() %>" name="hiddenTestN" />
 </div>
 </form>
</body>
</html>

需要注意的地方:

  1 GetToken()函數是為了獲得 Session里面保存的標志。
  2 Hidden使用了非服務器控件,這是因為我使用服務器控件,并在后臺直接獲取Session的標志并賦值給這個Hidden的時候,刷新提交到服務器的 表單中的Hidden的值也發生了改變,猜想是服務器控件的話,表單里面的值是保持同步的,當然,也可能是我用的方法不對,嘎嘎。

下面是后臺代碼:

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Security.Cryptography;
using System.Text;

namespace Test.Web
{

 public partial class Default : System.Web.UI.Page
 {
 protected void Page_Load(object sender, EventArgs e)
 {
 //第一次載入的時候,生成一個初始的標志
 if (null == Session["Token"])
 {
 SetToken();
 }
 }
 protected void Button1_Click(object sender, EventArgs e)
 {
 if (Request.Form.Get("hiddenTestN").Equals(GetToken()))
 {
 lblMessage.ForeColor = System.Drawing.Color.Blue;
 lblMessage.Text = "正常提交表單";
 SetToken();//別忘了最后要更新Session中的標志
 }
 else
 {
 lblMessage.ForeColor = System.Drawing.Color.Red;
 lblMessage.Text = "刷新提交表單";
 }
 }
 //獲得當前Session里保存的標志
 public string GetToken()
 {
 if (null != Session["Token"])
 {
 return Session["Token"].ToString();
 }
 else
 {
 return string.Empty;
 }
 }
 //生成標志,并保存到Session
 private void SetToken()
 {
 Session.Add("Token", UserMd5(Session.SessionID + DateTime.Now.Ticks.ToString()));
 }
 //這個函數純粹是為了讓標志稍微短點兒,一堆亂碼還特有神秘感,另外,這個UserMd5函數是網上找來的現成兒的
 protected string UserMd5(string str1)
 {
 string cl1 = str1;
 string pwd = "";
 MD5 md5 = MD5.Create();
 // 加密后是一個字節類型的數組
 byte[] s = md5.ComputeHash(Encoding.Unicode.GetBytes(cl1));
 // 通過使用循環,將字節類型的數組轉換為字符串,此字符串 是常規字符格式化所得
 for (int i = 0; i < s.Length; i++)
 {
 // 將得到的字符串使用十六進制類型格式。格式后的字符是 小寫的字母,如果使用大寫(X)則格式后的字符是大寫字符
 pwd = pwd + s[i].ToString("X");
 }
 return pwd;
 }
 }
}

需要注意的地方:

    1 在頁面第一次載入的時候要生成標志,以后就不用了。
    2 在表單處理的函數的最后,記得要更新標志。
    3 標志我選用了當前SessionID加上當前時間毫秒值,這樣基本可以避免標志重復,之后進行了一次MD5,純粹為了讓標志短點兒,當然有一點點安全的意 思,哈哈。
所有代碼就是這些,很簡單,不知道是因為太簡單還是大家有更好的方法,我在網上沒有找到類似的代碼,所以寫下來和大家分享,如果有更好的方法,希望可以告訴我,因為好久不做Web開發了,怕是有很多新技術都不會了。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

ASP.NET中防止頁面刷新造成表單重復提交執行兩次操作

ASP.NET中防止頁面刷新造成表單重復提交執行兩次操作:之前看過別人防刷新的方法,是讓頁面刷新或返回上一步讓頁面過期,這里介紹一種另類的方法,使用Session來處理。 實現原理: 由于刷新提交表單,實際上提交的就是上一次正常提交的表單,所以我們只要做一個標志,判斷出是新表單還是上一次的舊表單就可以分辨
推薦度:
標簽: 操作 刷新 提交
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 宁都县| 家居| 和林格尔县| 平谷区| 道孚县| 丁青县| 遂宁市| 华亭县| 宁阳县| 墨竹工卡县| 上思县| 鄯善县| 肇东市| 乐陵市| 合江县| 施甸县| 大埔区| 历史| 北票市| 临海市| 昌邑市| 奉新县| 临颍县| 桐柏县| 五常市| 庆元县| 苏尼特右旗| 岳阳市| 舞阳县| 公主岭市| 阳泉市| 宣武区| 合水县| 盐山县| 南投县| 隆子县| 金川县| 仙桃市| 鄂州市| 上栗县| 海兴县|