国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

在ASP中限制同一表單被多次提交

2024-05-04 11:07:05
字體:
來源:轉載
供稿:網友

本文介紹在ASP應用中防止用戶在當前會話期間多次提交同一表單的一個簡單方法。它主要由四個子程序組成,在較為簡單的應用場合,你只要將這些代碼放在包含文件中直接引用即可;對于那些較為復雜的環境,我們在文章的最后給出一些改進建議。

  一、基本工作過程

  下面我們依次討論這四個子程序。

  (一)初始化

  這里我們要在Session對象中保存兩個變量,其中:

  ⑴ 每一個表單對應一個稱為FID的唯一標識,為使該值唯一要用到一個計數器。

  ⑵ 每當一個表單成功提交,必須在一個Dictionary對象中存儲它的FID。

  我們用一個專用的過程來初始化上述數據。雖然以后各個子程序都要調用它,但實際上每一個會話期間它只執行一次:

Sub InitializeFID()
  If Not IsObject(Session("FIDList")) Then
  Set Session("FIDList")=Server.CreateObject("Scripting.Dictionary")
  Session("FID")=0
  End If
  End Sub

  (二)生成表單的唯一標識符

  下面這個函數GenerateFID()用于生成表單的唯一標志。該函數首先將FID值加1,然后返回它:


  Function GenerateFID()
  InitializeFID
  Session("FID") = Session("FID") + 1
  GenerateFID = Session("FID")
  End Function

  (三)登記已提交表單

  當表單成功地提交時,在Dictionary對象中登記它的唯一標識:


  Sub RegisterFID()
  Dim strFID
  InitializeFID
  strFID = Request("FID")
  Session("FIDlist").Add strFID, now()
  End Sub

  (四)檢查表單是否重復提交

  在正式處理用戶提交的表單之前,應該在Dictionary對象中檢查它的FID是否已經登記。下面的CheckFID()函數用來完成這個工作,如已經登記,它返回FALSE,否則返回TRUE:

Function CheckFID()
  Dim strFID
  InitializeFID
  strFID = Request("FID")
  CheckFID = not Session("FIDlist").Exists(strFID)
  End Function

  二、如何使用

  有兩個地方要用到上述函數,即表單生成時與結果處理時。假設上述四個子程序已經放入包含文件Forms.inc中,下面的代碼根據FID值來決定生成表單還是處理表單結果,它所描述的處理過程適合于大多數ASP應用:


  < %Option Explicit%>
  < !--#include file="forms.inc"-->
  < HTML>
  < HEAD>
  < TITLE>表單提交測試< /TITLE>
  < /HEAD
  < BODY>
  < %
  If Request("FID") = "" Then
  GenerateForm
  Else
  ProcessForm
  End If
  %>
  < /BODY>
  < /HTML>

  GenerateForm負責生成表單,表單中應該含有一個隱藏的FID,如:

< %
  Sub GenerateForm()
  %>
  < form action="< %=Request.ServerVariables("PATH_INFO")%>" method=GET>
  < input type=hidden name=FID value="< %=GenerateFID()%>">
  < input type=text name="param1" value="">
  < input type=submit value="OK">
  < /form>
  < %
  End Sub
  %>

  ProcessForm負責處理通過表單提交的內容,但在處理之前應該先調用CheckFID()檢查當前表單是否已經提交,代碼類如:


  < %
  Sub ProcessForm()
  If CheckFID() Then
  Response.Write "你輸入的內容是" & Request.QueryString("param1")
  RegisterFID
  Else
  Response.Write "此表單只能提交一次!"
  End If
  End Sub
  %>

  三、限制與改進措施

  上面我們介紹了在當前會話期間限制同一表單被多次提交的一種方法。在實際應用中可能需要從多方面加以改進,例如:

  ⑴ 在登記表單ID之前檢查用戶輸入數據的合法性,使得數據不合法時用戶可以按“后退”按鈕返回,在修正后再次提交同一表單。

  ⑵ 這種對表單提交的限制最多只能在當前會話期間有效。如果要求這種限制能夠跨越多個會話,那么就要用到Cookeis或數據庫來保存相關數據了。

  ⑶ 這種方法是不安全的。它僅用于防范誤操作,不能防止熟練用戶有意地多次提交同一表單。 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜兰市| 清原| 修武县| 博乐市| 巴林右旗| 平远县| 辰溪县| 天祝| 宁强县| 革吉县| 聂荣县| 雅江县| 塔城市| 惠州市| 霍山县| 太保市| 泾源县| 南通市| 宁河县| 正镶白旗| 信丰县| 镇赉县| 凯里市| 肇东市| 织金县| 佛教| 莒南县| 江达县| 蓬安县| 玛纳斯县| 慈利县| 徐汇区| 延庆县| 阿拉善左旗| 米易县| 安图县| 郓城县| 河津市| 剑阁县| 上栗县| 花莲县|