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

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

字符类型的
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

最好把“:”也过滤掉
建议用CHR()代替

关于Asp的SQL Injection预防问题,似乎已经没什么可说的了。在我做的Asp的项目里面,

都是用自己写的函数来处理客户端提交进来的数据,我的Blog里面也贴过这个函数。

具体可以参考http://blog.csdn.net/cqq/archive/2004/09/23/113786.aspx


不过,从朋友的留言和网上其他的一些讲如何防范SQL Injection的函数来看,很多人都走进了一个误区。

SQL Injection的危害是很大的,比如对于SQL Server,可以创建、删除数据库,执行系统命令等等, 如

drop table tbl_name, execute master.dbo.xp_cmdshell "command"

所以很多人写的函数就是拼命的去过滤这些可能引起危害的关键词,比如drop ,分号,and,exe,mid等等,罗列了

一大堆。


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

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


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

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


现在网上说的能够绕过单引号的攻击,其实是针对数字类型的

如果对于过滤了单引号的字符型,还有办法绕过,那就没得玩了........

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值