变态重口极致另类在线-波多久久夜色精品国产-波多野结衣在线观看一区-波多野结衣在线观看一区二区-污污的网站免费阅读-污污视频网址

當(dāng)前位置:首頁文章首頁 IT學(xué)院 IT技術(shù)

ASP中如何防止同一份表單被重復(fù)提交

作者:  來源:  發(fā)布時間:2011-6-13 15:05:35  點擊:

這篇文章主要跟大家分享學(xué)習(xí)的是關(guān)于在ASP應(yīng)用中如何限制同一表單被多次提交,希望能給大家?guī)韼椭騿l(fā)。

在Internet上我們每天都會遇到數(shù)不清的表單,也看到其中大部分并沒有限制用戶多次提交同一個表單。缺乏這種限制有時候會產(chǎn)生某些預(yù)料不到的結(jié)果,如重復(fù)訂閱郵件服務(wù)或重復(fù)投票等。

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

  一、基本工作過程

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

  (一)初始化

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

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

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

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

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

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

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

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

  (三)登記已提交表單

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

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

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

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

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

  二、如何使用

  有兩個地方要用到上述函數(shù),即表單生成時與結(jié)果處理時。假設(shè)上述四個子程序已經(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)該含有一個隱藏的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)前會話期間限制同一表單被多次提交的一種方法。在實際應(yīng)用中可能需要從多方面加以改進(jìn),例如:

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

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

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

相關(guān)軟件

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
主站蜘蛛池模板: 国产毛片a级 | 欧美末成年video水多 | 插一插射一射视频 | 成年人免费观看的视频 | 亚洲精品人成网线在线 | 在线观看亚洲天堂 | 中文字幕在线视频免费观看 | 日本一区不卡视频 | 三级网站日本 | 免费一级视频在线播放 | 亚洲精品网站在线观看不卡无广告 | 免费观看日批视频 | 国产精品国产 | 欧美精品videosex极品 | 在线a人片免费观看不卡 | 欧美丝袜老师 | 日本国产最新一区二区三区 | 在线日韩欧美 | 亚洲图片二区 | 日韩欧国产精品一区综合无码 | 日韩理论在线 | 精品视频在线v | 182tv成人午夜在线观看 | 日本黄色影片在线观看 | 男女毛片视频 | 5060午夜电视网 | freexxxx性| 欧美日韩视频二区三区 | 一级a级毛片 | 欧美午夜性刺激在线观看免费 | 99热精品一区 | 久久综合九色综合97小说 | 国产精品欧美久久久久天天影视 | 亚洲视频精品在线观看 | 午夜性生活片 | 九九热播视频 | 欧美jizzhd精品欧美另类 | 国产日韩欧美在线一二三四 | 在线中文字日产区乱码 | 久久久久夜色精品波多野结衣 | 国产免费黄色 |