超碰人人人人人,亚洲AV午夜福利精品一区二区,亚洲欧美综合区丁香五月1区,日韩欧美亚洲系列

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

ASP、Request對象與SQL注入

admin
2011年2月15日 23:13 本文熱度 3247
Request對象探討

Request是ASP里的一個內(nèi)部對象,用于獲取HTTP請求中傳遞的任意信息(如頭信息、表單數(shù)據(jù)、cookies等等)。所以這是在ASP里面最常用的內(nèi)部對象,常用來獲得GET方式提交的數(shù)據(jù)(Request.QueryString)、表單POST提交的數(shù)據(jù)(Request. Form)和Cookies(Request.Cookies)。

我們用Request對象可以指定獲取某個特定方式提交的數(shù)據(jù)。比如我們用這段代碼獲得通過POST提交的數(shù)據(jù)lake2的值:request.Form("lake2");而request.queryString("CSDN")獲得GET方式提交的CSDN的值。

對于獲取HTTP數(shù)據(jù),ASP還給了我們一個更簡單的方法:request(key),即直接使用request而不指定數(shù)據(jù)集合。此時ASP會依次在QueryString、From、Cookies、ServerVariables、ClientCertificate、Browser中檢查匹配的數(shù)據(jù),若發(fā)現(xiàn)則返回數(shù)據(jù)。

上面6個集合中,ServerVariables、ClientCertificate和Browser的變量是固定了的;而QueryString、From、Cookies的變量可以任意指定。想不到Cookies可以拿來傳遞任意數(shù)據(jù),以前倒沒有注意。

OK,test一下先。在本地web目錄新建test.asp文件,內(nèi)容為:<%=request("b")%>

Step 1:直接訪問http://127.0.0.1/test.asp?b=la<b>k</b>e2,瀏覽器顯示lake2

Step 2:構造表單提交結果也如step 1

Step 3: 構造表單,GET傳遞b值為"He",同時POST的b為"She",瀏覽器顯示為"He"。呵呵,按前面的排序有個優(yōu)先級的

Step 4:Telnet到本地80端口,構造HTTP請求如下(注意Cookies哦):

GET /test.asp HTTP/1.1
Accept: */*
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; TencentTraveler ; .NET CLR 1.1.4322)
Host: 127.0.0.1
Connection: Keep-Alive
Cookie: b=lake2 , Success !

在一堆服務器響應數(shù)據(jù)之后,我們看到了"lake2,Success!"(Q:為什么空格不見了?A:因為未對提交的空格進行URL編碼)。

到此,我們已理論和實際相結合的證明了Cookies可以拿來傳遞數(shù)據(jù)。

Request對象與SQL注入

現(xiàn)在把話題轉一下,我們來說說SQL Injection。

SQL注入攻擊是由于Web應用程序沒有過濾用戶所提交的有害數(shù)據(jù)而導致危害服務器的一種攻擊手法。注意咯,這里涉及到提交數(shù)據(jù),自然要跟剛才說了一大堆的request聯(lián)系上啊。

歸根結底,ASP下面的SQL注入都是由于request的參數(shù)沒有過濾或者過濾不嚴。當然,程序員不是安全專家,他們可能不知道如何過濾。

于是,網(wǎng)絡上就出現(xiàn)了通用的防注入ASP程序——"SQL通用防注入系統(tǒng)"。經(jīng)過一段時間和幾個作者的改進,該程序已經(jīng)比較完善了,基本上可以攔截SQL注入(但是,個人認為它的過濾方式太嚴,造成許多不便)。"SQL通用防注入系統(tǒng)"是個asp文件,只需在有參數(shù)提交的文件中include它就是了。程序過濾的原理是遍歷GET和POST參數(shù)的值,發(fā)現(xiàn)SQL注入關鍵字(如and、select)就停止正常文件執(zhí)行。

嘿嘿,它遍歷GET和POST,也就是Request對象的QueryString和From集合,忽略了Cookies。

現(xiàn)在,我們假設有一個SQL Injection漏洞百出的ASP程序,具備網(wǎng)絡安全知識的管理員同學在網(wǎng)上下載并使用了傳說中的"SQL通用防注入系統(tǒng)",但是很不幸,ASP程序中所有獲取參數(shù)都是使用的request(key)……(呵呵,眼看著一個個封鎖被突破,那是很enjoy的事情^_^)

這里僅僅是假設而已,至于實際中到底有多少ASP程序員喜歡用request(key) 來獲取數(shù)據(jù)就不得而知咯。

該文章在 2011/2/15 23:13:01 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業(yè)務管理,結合碼頭的業(yè)務特點,圍繞調度、堆場作業(yè)而開發(fā)的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved