資源描述:
《asp net表單驗(yàn)證方法詳解》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫(kù)。
1、ASPNET表單驗(yàn)證方法詳解ASP.NET表單驗(yàn)證方法詳解2011-01-1014:33在表單提交的時(shí)候,經(jīng)常需要對(duì)錄入信息的長(zhǎng)度、格式、內(nèi)容等進(jìn)行驗(yàn)證,以便獲得合理的信息。在ASP.NET開(kāi)發(fā)中主要的驗(yàn)證方法,我總結(jié)了一下,主要有一下幾種,如有不足之處請(qǐng)朋友們予以指出。1、使用驗(yàn)證控件這屬于客戶端驗(yàn)證,微軟開(kāi)發(fā)人員將最常用的驗(yàn)證功能進(jìn)行了封裝,使得我們開(kāi)發(fā)效率明顯提高,而且特別是自定義驗(yàn)證控件,非常靈活,我們可以自行設(shè)計(jì)驗(yàn)證邏輯。但是驗(yàn)證控件收到了瀏覽器的限制,記得在一次開(kāi)發(fā)過(guò)程中,使用FireFox瀏覽器進(jìn)行瀏覽,發(fā)現(xiàn)所有的驗(yàn)證控件失靈,這個(gè)并
2、非是ASP.NET設(shè)計(jì)的漏洞,只能說(shuō)瀏覽器標(biāo)準(zhǔn)的不唯一造成的。ASP.NET公有六種驗(yàn)證控件,分別如下:RequiredFieldValidator(必須字段驗(yàn)證)用于檢查是否有輸入值CompareValidator(比較驗(yàn)證)按設(shè)定比較兩個(gè)輸入RangeValidator(范圍驗(yàn)證)輸入是否在指定范圍RegularExpressionValidator(正則表達(dá)式驗(yàn)證)正則表達(dá)式驗(yàn)證控件CustomValidator(自定義驗(yàn)證)自定義驗(yàn)證控件ValidationSummary(驗(yàn)證總結(jié))總結(jié)驗(yàn)證結(jié)果2、使用JS驗(yàn)證JS驗(yàn)證,出現(xiàn)的比較早,也屬于
3、客戶端驗(yàn)證,其靈活、適用的性能深得人們的喜好。3、后臺(tái)程序驗(yàn)證盡管客戶端驗(yàn)證比較靈活,但是其局限性也很明顯,服務(wù)器端驗(yàn)證必不可少。(1)安全性如若惡意攻擊者,將客戶端頁(yè)面的驗(yàn)證控件和JS驗(yàn)證全部抹去,而服務(wù)器端又沒(méi)有做出有效的驗(yàn)證處理,必將給攻擊者帶來(lái)很大的漏洞,其后果不堪設(shè)想。(2)客戶端驗(yàn)證的局限性,比如用戶注冊(cè),需要判定用戶名是否存在,這個(gè)需要從數(shù)據(jù)庫(kù)查詢進(jìn)行判定.(3)功能強(qiáng)大各種驗(yàn)證功能都可以在這里實(shí)現(xiàn)。缺點(diǎn):增加服務(wù)器端負(fù)擔(dān)4、Ajax類的驗(yàn)證這個(gè)結(jié)合了客戶端驗(yàn)證和服務(wù)器端驗(yàn)證。因?yàn)槭褂胊jax框架,性能上付出的代價(jià)較小,但是用戶體驗(yàn)和
4、編碼的簡(jiǎn)易度提高了。而在進(jìn)行驗(yàn)證過(guò)程中,對(duì)于不同格式的驗(yàn)證,就需要強(qiáng)大靈活的正則表達(dá)式了。使用正則表達(dá)式進(jìn)行驗(yàn)證:在編寫(xiě)處理字符串的程序或網(wǎng)頁(yè)時(shí),經(jīng)常會(huì)有查找符合某些復(fù)雜規(guī)則的字符串的需要。正則表達(dá)式就是用于描述這些規(guī)則的工具。換句話說(shuō),正則表達(dá)式就是記錄文本規(guī)則的代碼。正則表達(dá)式用于字符串處理、表單驗(yàn)證等場(chǎng)合,實(shí)用高效,所以其應(yīng)用非常廣泛,下面我就通過(guò)幾個(gè)例子來(lái)說(shuō)明正則表達(dá)式在驗(yàn)證中的具體應(yīng)用。在這里我以驗(yàn)證電話號(hào)碼的格式為例進(jìn)行介紹。1使用JS驗(yàn)證復(fù)制代碼代碼如下:asp:ButtonID="Button2"runat="server"Text
5、="測(cè)試"OnClientClick="returncheckCellPhone();"OnClick="Button2_Click"/驗(yàn)證手機(jī)的JS代碼復(fù)制代碼代碼如下:scripttype="text/javascript"functioncheckCellPhone()//驗(yàn)證手機(jī){varmobile=document.getElementById("tbMobile").value;if(mobile!=""){varreg0=/^13d{5,9}$/;//130--139。至少7位varreg1=/^153d{4,8}$/;//聯(lián)通1
6、53。至少7位varreg2=/^159d{4,8}$/;//移動(dòng)159。至少7位varreg3=/^158d{4,8}$/;//移動(dòng)158。至少7位if(reg0.test(mobile)
7、
8、reg1.test(mobile)
9、
10、reg2.test(mobile)
11、
12、reg3.test(mobile)){returntrue;}else{alert("手機(jī)號(hào)格式錯(cuò)誤!");document.getElementById("tbMobile").focus();returnfalse;}}else{alert("手機(jī)號(hào)不能為空!");docum
13、ent.getElementById("tbMobile").focus();returnfalse;}}/script在表單提交的時(shí)候,經(jīng)常需要對(duì)錄入信息的長(zhǎng)度、格式、內(nèi)容等進(jìn)行驗(yàn)證,以便獲得合理的信息。在ASP.NET開(kāi)發(fā)中主要的驗(yàn)證方法,我總結(jié)了一下,主要有一下幾種,如有不足之處請(qǐng)朋友們予以指出。2使用驗(yàn)證控件自定義驗(yàn)證控件:復(fù)制代碼代碼如下:asp:CustomValidatorID="CustomValidator2"runat="server"ControlToValidate="tbMobile"ClientValidationFun
14、ction="checkCellPhone"/asp:CustomValidator正則表達(dá)式驗(yàn)證控件(當(dāng)然這種方法需要加