轉帖|其它|編輯:郝浩|2008-12-17 11:42:41.000|閱讀 979 次
概述:在ASP應用中如何限制同一表單被多次提交
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
文章關鍵字:|ASP|限制|表單|提交|
在Internet上我們每天都會遇到數不清的表單,也看到其中大部分并沒有限制用戶多次提交同一個表單。缺乏這種限制有時候會產生某些預料不到的結果,如重復訂閱郵件服務或重復投票等。
本文介紹在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
?。ǘ┥杀韱蔚奈ㄒ粯俗R符
下面這個函數GenerateFID()用于生成表單的唯一標志。該函數首先將FID值加1,然后返回它:
以下為引用的內容:
Function GenerateFID()
InitializeFID
Session("FID") = Session("FID") 1
GenerateFID = Session("FID")
End Function
?。ㄈ┑怯浺烟峤槐韱?/p>
當表單成功地提交時,在Dictionary對象中登記它的唯一標識:
以下為引用的內容:
Sub RegisterFID()
Dim strFID
InitializeFID
strFID = Request("FID")
Session("FIDlist").Add strFID, now()
End Sub
?。ㄋ模z查表單是否重復提交
在正式處理用戶提交的表單之前,應該在Dictionary對象中檢查它的FID是否已經登記。下面的CheckFID()函數用來完成這個工作,如已經登記,它返回FALSE,否則返回TRUE:
以下為引用的內容:
Function CheckFID()
Dim strFID
InitializeFID
strFID = Request("FID")
CheckFID = not Session("FIDlist").Exists(strFID)
End Function [SPAN]
二、如何使用
有兩個地方要用到上述函數,即表單生成時與結果處理時。假設上述四個子程序已經放入包含文件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 "你輸入的內容是"
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉載自:中國站長站