一个asp函数, 解决SQL Injection漏洞

王朝asp·作者佚名  2006-11-24
宽屏版  字体: |||超大  

/**

作者:慈勤强

Email: cqq1978@Gmail.com

*/

函数很简单, 主要是针对字符串和数字两种类型的传入数据分别进行了处理,具体用法:

字符类型的

strUsername = CheckInput(Request(“username“),“s“)

数字类型的

ID = CheckInput(Request(“id“),“i“)

下面是函数

Function CheckInput(str,strType)

'函数功能:过滤字符参数中的单引号,对于数字参数进行判断,如果不是数值类型,则赋值0

'参数意义: str ---- 要过滤的参数

' strType ---- 参数类型,分为字符型和数字型,字符型为"s",数字型为"i"

Dim strTmp

strTmp = ""

If strType ="s" Then

strTmp = Replace(Trim(str),"'","''")

ElseIf strType="i" Then

If isNumeric(str)=False Then str="0"

strTmp = str

Else

strTmp = str

End If

CheckInput = strTmp

End Function

SQL Injection的危害是很大的,比如对于SQL Server,可以创建、删除数据库,执行系统命令等等, 如drop table tbl_name, execute master.dbo.xp_cmdshell "command"所以很多人写的函数就是拼命的去过滤这些可能引起危害的关键词,比如drop ,分号,and,exe,mid等等,罗列了一大堆。

其实,尽可以不必那么繁琐,非要把简单的事情复杂化。

对于过滤,ASP中只要针对字符型和数字型分别处理就可以了,

字符型的,把单引号转换成两个单引号 strTmp = Replace(Trim(str),"'","''")

数字型的,就判断是否能够转换成数字型的 ,用 isNumeric函数

现在网上说的能够绕过单引号的攻击,其实是针对数字类型的,如果对于过滤了单引号的字符型,还有办法绕过,那就没得玩了........

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有