快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

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

/**
作者:慈勤强
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函数

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


返回类别: 教程
上一教程: 数 据 库 设 计 经 验 谈
下一教程: StoredProcedure在企业网站开发中的应用(1)

您可以阅读与"一个asp函数, 解决SQL Injection漏洞"相关的教程:
· 一个ASP函数,解决SQL INJECTION漏洞
· ASP整合的一个SQL语句类
· ASP+ACCESS莫名奇妙的SQL语句错误解决
· 一个用C#写的扫描ASP源码漏洞的应用程序(续)
· ASP漏洞分析和解决方式
    微笑服务 优质保证 索取样品