清风的blog 优然探索

ASP防止SQL注入

function gosql

Dim Fy_Post,Fy_Get,Fy_In,Fy_Inf,Fy_Xh,Fy_db,Fy_dbstr,Kill_IP,WriteSql
Fy_In = "'|;|and|(|)|exec|insert|select|delete|update|count|*|%|chr|mid|master|truncate|char|declare"
Kill_IP=True
WriteSql=True  
'----------------------------------


Fy_Inf = split(Fy_In,"|")
'--------POST部份------------------
If Request.Form<>"" Then
For Each Fy_Post In Request.Form
   For Fy_Xh=0 To Ubound(Fy_Inf)
    If Instr(LCase(Request.Form(Fy_Post)),Fy_Inf(Fy_Xh))<>0 Then
     If WriteSql=True Then
      killSqlconn.Execute("insert into SqlIn(Sqlin_IP,SqlIn_Web,SqlIn_FS,SqlIn_CS,SqlIn_SJ) values('"&Request.ServerVariables("REMOTE_ADDR")&"','"&Request.ServerVariables("URL")&"','POST','"&Fy_Post&"','"&replace(Request.Form(Fy_Post),"'","''")&"')")
   
      Set killSqlconn = Nothing
     End If
     Response.Write "<Script Language=JavaScript>alert('SQL通用防注入系统提示你↓\n\n请不要在参数中包含非法字符尝试注入!\n');</Script>"
     Response.Write "非法操作!系统做了如下记录↓<br>"
     Response.Write "操作IP:"&Request.ServerVariables("REMOTE_ADDR")&"<br>"
     Response.Write "操作时间:"&Now&"<br>"
     Response.Write "操作页面:"&Request.ServerVariables("URL")&"<br>"
     Response.Write "提交方式:POST<br>"
     Response.Write "提交参数:"&Fy_Post&"<br>"
     Response.Write "提交数据:"&Request.Form(Fy_Post)
     Response.End
    End If
   Next
Next
End If
'----------------------------------

'--------GET部份-------------------
If Request.QueryString<>"" Then
For Each Fy_Get In Request.QueryString
   For Fy_Xh=0 To Ubound(Fy_Inf)
    If Instr(LCase(Request.QueryString(Fy_Get)),Fy_Inf(Fy_Xh))<>0 Then
     If WriteSql=True Then
     
     End If
     Response.Write "<Script Language=JavaScript>alert('SQL通用防注入系统提示你↓\n\n请不要在参数中包含非法字符尝试注入!\n');</Script>"
     Response.Write "非法操作!系统做了如下记录↓<br>"
     Response.Write "操作IP:"&Request.ServerVariables("REMOTE_ADDR")&"<br>"
     Response.Write "操作时间:"&Now&"<br>"
     Response.Write "操作页面:"&Request.ServerVariables("URL")&"<br>"
     Response.Write "提交方式:GET<br>"
     Response.Write "提交参数:"&Fy_Get&"<br>"
     Response.Write "提交数据:"&Request.QueryString(Fy_Get)
     Response.End
    End If
   Next
Next
End If

end function

gosql

2010年7月14日 | 发布:admin | 分类:技术文章 | 评论:0

发表留言: