Jquery中request和request.form和request.querystring的區(qū)別
Request.Form是獲取以POST方式提交的表單數(shù)據(jù);
Request.QueryString主要是獲取地址欄參數(shù)或者以Get方式提交的數(shù)據(jù)
而Request則包含以上兩種方式,會(huì)在Request.QueryString和Request.Form中都查詢一遍變量。但是優(yōu)先獲取GET方式提交的數(shù)據(jù),即Request.QueryString
Request:包含以上兩種方式(優(yōu)先獲取GET方式提交的數(shù)據(jù)),它會(huì)在QueryString、Form、ServerVariable中都搜尋一遍。
而且有時(shí)候也會(huì)得到不同的結(jié)果。如果你僅僅是需要Form中的一個(gè)數(shù)據(jù),但是你使用了Request而不是Request.Form,那么程序?qū)⒃?QueryString、ServerVariable中也搜尋一遍。
如果正好你的QueryString或者ServerVariable里面也有同名 的項(xiàng),你得到的就不是你原本想要的值了。
request.querystring 是用來接收地址里面?后面的xx=xx的內(nèi)容
而request.form 是用來接收表單遞交來的數(shù)據(jù)
例如 request("offline")
就無論采用的是以上哪種方法的字段值都可以讀取了
request.form是指用form遞交過來的數(shù)據(jù)。而request.querystring則是指用URL遞交過來的。你用的是login.asp?offline=true,這個(gè)當(dāng)然是URL遞交的啦。
Request.Form和Request.QueryString兩個(gè)接收參數(shù)來源不同,前者是接收從表單Form來的參數(shù),后者是從URL來的參數(shù)。
你這有這一句logon.asp?offline=true這是URL的傳遞參數(shù)。
如果要用Request.Form()的話,那頁面至少得有個(gè)表單,比如:
<form name=form1 method=post action=logon.asp> <input type=text name=user value=""> </form>
這樣在提交過表單后,就可以用Request.Form("user")得到這個(gè)文本框傳遞過來得數(shù)值。
request.querystring和request.form的區(qū)別
request.querystring是用post方法讀取的 不安全
request.form是用get方法讀取的
form表單中的method中看你是get還是post
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>無標(biāo)題文檔</title>
</head>
<body>
<p>
<%
if request.querystring("offline")="true" then
session.Abandon()
response.Redirect("login1.htm")
end if
%>
歡迎進(jìn)入:<%=request.Form("user")%></p>
<p>當(dāng)前聯(lián)機(jī)人數(shù)為:</p><%=application("onlinenum")%>
<p><a href=login.asp?offline=true>離開</a></p>
</body>
</html>
總結(jié);
1.Request.form方法,它是用來接收表單變量的(post 方法)
2.Request.QueryString方法, 它是接收URL參數(shù)的 (get 方法)
3.Request對(duì)象也可以不指明具體使用QueryString或是form方法,如request("變量"),因?yàn)樗茏詣?dòng)識(shí)別,不過還是 指明為好,否則,要它自己判斷也得花些微時(shí)間,影響程序執(zhí)行效率。Request:包含以上兩種方式(優(yōu)先獲取GET方式提交的數(shù)據(jù)),它會(huì)在 QueryString、Form、ServerVariable中都搜尋一遍。
兩者除了接收方法不同外,還有傳遞數(shù)據(jù)量大小的問題,request.form方法能接收的數(shù)據(jù)沒有限制,而 request.QueryString只能接收數(shù)據(jù)量小于2KB數(shù)據(jù),當(dāng)然后者的執(zhí)行速度要比前者快。一般往數(shù)據(jù)庫請(qǐng)求查詢時(shí)用 request.QueryString方法,因?yàn)椴樵儠r(shí)只不過那么幾個(gè)關(guān)鍵詞,沒有必要用request.form方法而導(dǎo)致查詢速度變慢。另 外,request.QueryString方法還會(huì)把數(shù)據(jù)信息顯示在客戶端瀏覽器地址欄中,安全性較差。 request.form方法不存在上述問 題,因此大量被應(yīng)用在多個(gè)文本域提交數(shù)據(jù)和用戶登陸的場(chǎng)合
ps:get和post的區(qū)別
get方法把參數(shù)及參數(shù)值暴露給訪客,所以是不安全的。而且url傳送的參數(shù)長(zhǎng)度有限,但便捷。
post方法傳送的參數(shù)長(zhǎng)度可以很大,而且參數(shù)及參數(shù)值不被訪客所看到。
總結(jié):
在使用request("Reportdate")讀取傳遞的數(shù)據(jù)“Reportdate”對(duì)應(yīng)的值的時(shí)候,無論是get方式還是post方式傳送的參數(shù)都可以讀到,原因是它默認(rèn)先使用request.querystring讀取然后用request.form讀取,也就是,做了兩遍讀取的操作,速度自然會(huì)慢一些,也不安全。
例子:
public string ReportDate
{
get { return Request.QueryString["reportDate"]; }
}
request對(duì)象有五個(gè)集合,下面予以介紹:
QueryString
:用以獲取客戶端附在url地址后的查詢字符串中的信息。
例如:stra=Request.QueryString ["strUserld"]
Form
:用以獲取客戶端在FORM表單中所輸入的信息。(表單的method屬性值需要為POST)
例如:stra=Request.Form["strUserld"]
Cookies
:用以獲取客戶端的Cookie信息。
例如:stra=Request.Cookies["strUserld"]
ServerVariables
:用以獲取客戶端發(fā)出的HTTP請(qǐng)求信息中的頭信息及服務(wù)器端環(huán)境變量信息。
例如:stra=Request.ServerVariables["REMOTE_ADDR"],返回客戶端IP地址
ClientCertificate
:用以獲取客戶端的身份驗(yàn)證信息
例如:stra=Request.ClientCertificate["VALIDFORM"],對(duì)于要求安全驗(yàn)證的網(wǎng)站,返回有效起始日期。
- asp.net中“從客戶端中檢測(cè)到有潛在危險(xiǎn)的Request.Form值”錯(cuò)誤的解決辦法
- ASP.NET檢測(cè)到不安全 Request.Form 值解決方案匯總
- ASP.NET從客戶端中檢測(cè)到有潛在危險(xiǎn)的request.form值的3種解決方法
- 有潛在危險(xiǎn)的 Request.Form 值避免方法
- ASP.NET中Request.Form中文亂碼的解決方法
- asp.net 從客戶端中檢測(cè)到有潛在危險(xiǎn)的 Request.Form 值錯(cuò)誤解
- 從客戶端檢測(cè)到有潛在危險(xiǎn)的Request.Form值的asp.net代碼
- C# Request.Form用法案例詳解
相關(guān)文章
JQuery手速測(cè)試小游戲?qū)崿F(xiàn)思路詳解
這篇文章主要介紹了JQuery手速測(cè)試小游戲?qū)崿F(xiàn)思路詳解,本文給大家介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
jquery實(shí)現(xiàn)回車鍵觸發(fā)事件(實(shí)例講解)
下面小編就為大家分享一篇jquery實(shí)現(xiàn)回車鍵觸發(fā)事件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-11-11
jquery動(dòng)畫4.升級(jí)版遮罩效果的圖片走廊--帶自動(dòng)運(yùn)行效果
我將上一章中了插件做了個(gè)小小的升級(jí),實(shí)現(xiàn)了自動(dòng)運(yùn)行效果,完整代碼大家見demo2012-08-08
jQuery使用數(shù)組編寫圖片無縫向左滾動(dòng)
jQuery編程實(shí)現(xiàn)一組由8幅圖組成的圖片,進(jìn)入網(wǎng)頁初始時(shí)顯示前面4張,然后自動(dòng)向左滾動(dòng),直到屏幕顯示的是后4張時(shí)停止?jié)L動(dòng),需要的朋友可以參考下2012-12-12

