公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

兩個小函數讓你的ASP程序對SQL注入免疫!

admin
2011年2月16日 1:0 本文熱度 3304

兩個小函數讓你的ASP程序對SQL注入免疫!


Rem ## 長整數轉換
Function toNum(s, default)
If IsNumeric(s) and s <> "" then
toNum = CLng(s)
Else
toNum = default
End If
End Function
Rem ## SQL 語句轉換
Function toSql(str)
If IsNull(str) Then str = ""
toSql = replace(str, "''", "''''")
End Function
示例:
Dim sql
Dim strWhere, strName, intAge
strName = toSql(request("user"))
intAge = toNum(request("age"), 20)
sql = "SELECT * FROM [USER]" & _
"WHERE [AGE] > " & strName & _
" AND [USERNAME] = ''" & intAge & "''"
一般情況下, 通過上面兩個函數的過慮, 可以杜絕網上的SQL注入攻擊!如果你覺得有需要, 可以加上對chr(0)的替換, 將toSql函數改為如下:
Function toSql(str)
If IsNull(str) Then str = ""
str = replace(str, chr(0), "")
toSql = replace(str, "''", "''''")
End Function
另注:
***********************************************************************
檢測外部提交的函數
Function CheckUrlRefer()
Dim strLocalUrl, intUrlLen, strUrlRefer
strLocalUrl = "intUrlLen = Len(strLocalUrl)
strUrlRefer = LCase(request.ServerVariables("HTTP_REFERER") & "")
''檢測前一個頁面是否來自 strLocalUrl
If Left(strUrlRefer, intUrlLen) = strLocalUrl Then
CheckUrlRefer = True
Else
CheckUrlRefer = False
End If
End Function
***********************************************************************
該函數可以幫助你抵擋外部的SQL注入測試, 只需要在頁面的頭部調用即可.
通過簡單的兩個小函數, 讓你的ASP程序更安全!
歡迎高手指正(請將繞過這兩個函數的方法寫出來)!
相關討論頁面:
http://community.csdn.net/Expert/TopicView.asp?id=3585010
http://community.csdn.net/Expert/TopicView.asp?id=3582230
http://community.csdn.net/Expert/topic/3589/3589480.xml?temp=.4866449
/////////////////////////////////////////////////////////////////////////////////////////////////////////////
dim qs,errc,iii
qs=request.servervariables("query_string")
dim nothis(18)
nothis(0)="net user"
nothis(1)="xp_cmdshell"
nothis(2)="/add"
nothis(3)="exec%20master.dbo.xp_cmdshell"
nothis(4)="net localgroup administrators"
nothis(5)="select"
nothis(6)="count"
nothis(7)="asc"
nothis(8)="char"
nothis(9)="mid"
nothis(10)="''"
nothis(11)=":"
nothis(12)=""""
nothis(13)="insert"
nothis(14)="delete"
nothis(15)="drop"
nothis(16)="truncate"
nothis(17)="from"
nothis(18)="%"
errc=false
for iii= 0 to ubound(nothis)
if instr(qs,nothis(iii))<>0 then
errc=true
end if
next
if errc then
Response.Write("對不起,非法URL地址請求!")
response.end
end if
***************************************************************
當然這方法做得太“絕”了,但是我也是沒有辦法啊。這個方法是在網上看到的,運行于一個網站上,現在一切良好。為了安全我只能這樣。我想只要有關SQL的敏感單詞都進行過濾掉應該沒有什么吧,當然像樓主的做到那一步是基本上可以了,可以修補一下用用。記得我最初用的是《SQL注入天書》上面提供的防范方法,后來才改用這個。
將我以前用的代碼也帖出來供參考,大家有興趣可以去百度或GOOGLE中搜索一下《SQL注入天書》了解
使用這個函數,對客戶端提交來的數據進行驗證。。。
<%
Function SafeRequest(ParaName,ParaType)
''--- 傳入參數 ---
''ParaName:參數名稱-字符型
''ParaType:參數類型-數字型(1表示以上參數是數字,0表示以上參數為字符)
Dim ParaValue
ParaValue=Request(ParaName)
If ParaType=1 then
If not isNumeric(ParaValue) then
Response.write "參數" & ParaName & "必須為數字型!"
Response.end
End if
Else
ParaValue=replace(ParaValue,"''","''''")
End if
SafeRequest=ParaValue
End function%>


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

主站蜘蛛池模板: 国产午夜福利片在线观看尤物 | 国产精品成人免费观看 | 国产国产久热这里只有精品 | 国产无码综合 | 国产动漫一区 | 国产91白浆在线观看 | 国产成人久久精品一区二区三 | 成在线人午夜剧场免费无码 | 国产成人午夜福利在线观看 | 国产高清a级毛片视频 | 国产精品成人精品天天看视频 | 91人成精品国产手机在线 | 国产三级国产经典国产av | 国产精品直播手机在线 | 国产av一区二区三区无码野战 | 国产精品日韩一区二区 | 国产午夜无码精 | 国产综合亚洲欧美另类久久久精品 | 91av国产精品| 2025久久国产精品免费热麻豆 | a片日韩美女视频免费 | 国产精品精品久久久久久一 | 国产ts人妖在线观看 | 波多野结衣中文字幕全集 | 国产一区二区三区免费精品 | 99精品无码一区二区毛片免费 | 国产成人免费观看 | 国产人人怕人人干视频 | 国产一区二区无码网站 | 成人日产国产av | 国产精品日韩欧美在线第一页 | 国产微拍精品一区二区 | 2025国产成人综 | 国产精品爆乳在线播放 | 国产免费内射又 | 精品一区二区三区免费 | 2025国产精品网站在线播放 | 国产福利永久不卡在线观看 | 97人妻精品 | av无码免费一区二区三区 | 国产麻豆精品精东影业av网站 |