大陆性a及毛片,日韩精品不卡,国产精品第四页,日韩黄在线观看,欧美三级一区二区,国产中出在线观看,日韩久久久精品

    電話

    0411-39943997

仟億科技
客服中心
  • 電話
  • 電話咨詢:0411-39943997
  • 手機(jī)
  • 手機(jī)咨詢:15840979770
    手機(jī)咨詢:13889672791
網(wǎng)絡(luò)營銷 >更多
您現(xiàn)在的位置:首頁 > 新聞中心 > 常見問題

網(wǎng)頁中限制同一表單被多次提交的ASP程序

作者:billionnet 發(fā)布于:2011/12/21 17:00:45 點(diǎn)擊量:

 

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

  一、基本工作過程

  下面我們依次討論這四個(gè)子程序。

 ?。ㄒ唬┏绦虺跏蓟?/strong>

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

 ?、?每一個(gè)表單對應(yīng)一個(gè)稱為FID的唯一標(biāo)識(shí),為使該值唯一要用到一個(gè)計(jì)數(shù)器。

  ⑵ 每當(dāng)一個(gè)表單成功提交,必須在一個(gè)Dictionary對象中存儲(chǔ)它的FID。

  我們用一個(gè)專用的過程來初始化上述數(shù)據(jù)。雖然以后各個(gè)子程序都要調(diào)用它,但實(shí)際上每一個(gè)會(huì)話期間它只執(zhí)行一次:

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

 ?。ǘ┥删W(wǎng)頁表單的唯一標(biāo)識(shí)符

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


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

 ?。ㄈ┑怯浘W(wǎng)頁已提交表單

  當(dāng)表單成功地提交時(shí),在Dictionary對象中登記它的唯一標(biāo)識(shí):


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

 ?。ㄋ模z查網(wǎng)頁表單是否重復(fù)提交

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

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

  二、如何使用

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


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

  GenerateForm負(fù)責(zé)生成表單,表單中應(yīng)該含有一個(gè)隱藏的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負(fù)責(zé)處理通過表單提交的內(nèi)容,但在處理之前應(yīng)該先調(diào)用CheckFID()檢查當(dāng)前表單是否已經(jīng)提交,代碼類如:


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

  三、限制與改進(jìn)措施

  上面我們介紹了在當(dāng)前會(huì)話期間限制同一表單被多次提交的一種方法。在實(shí)際應(yīng)用中可能需要從多方面加以改進(jìn),例如:

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

 ?、?這種對表單提交的限制最多只能在當(dāng)前會(huì)話期間有效。如果要求這種限制能夠跨越多個(gè)會(huì)話,那么就要用到Cookeis或數(shù)據(jù)庫來保存相關(guān)數(shù)據(jù)了。

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

 


分享到:


Copyright@ 2011-2016 版權(quán)所有:大連千億科技有限公司 遼ICP備11013762-3號(hào)   google網(wǎng)站地圖   百度網(wǎng)站地圖   網(wǎng)站地圖

公司地址:大連市沙河口區(qū)中山路692號(hào)辰熙星海國際2317 客服電話:0411-39943997 QQ:2088827823 37482752

法律聲明:未經(jīng)許可,任何模仿本站模板、轉(zhuǎn)載本站內(nèi)容等行為者,本站保留追究其法律責(zé)任的權(quán)利! 隱私權(quán)政策聲明