您的位置:首页 > 数据库

对sql注入和防止"or"="or"的修复方法!

2008-07-11 08:47 218 查看
1.现在3年前的漏洞还有很多站存在,login.asp后台用'or''='或'or'='or'者代替用户名密码获得管理员.

解决方法:搜索login.asp下的<from找到下边的



username=request.Form("name")

pass=request.Form("pass")

修改为

username=Replace(request.Form("name"), "'", "''")

pass=Replace(request.Form("pass"), "'", "''")

语法是屏蔽'和''这个来达到效果.

2.现在再介绍简单有效的傻瓜防止asp-sql注入的方法

在需要注入的页面顶部加入:

<!--#i nclude File="together.asp"-->

这个together.asp文件放在同1个目录

together.asp的内容如下:

<%

Dim Fy_Url,Fy_a,Fy_x,Fy_Cs(),Fy_Cl,Fy_Ts,Fy_Zx

'---定义部份 头------

Fy_Cl = 3 '处理方式:1=提示信息,2=转向页面,3=先提示再转向

Fy_Zx = "index.Asp" '出错时转向的页面

'---定义部份 尾------

'----------版权说明----------------

'miko SQL通用防注入 ASP版

'本程序由 凝聚信息安全团队 独立开发

'--------凝聚信息安全团队 版权所有-----------

On Error Resume Next

Fy_Url=Request.ServerVariables("QUERY_STRING")

Fy_a=split(Fy_Url,"&")

redim Fy_Cs(ubound(Fy_a))

On Error Resume Next

for Fy_x=0 to ubound(Fy_a)

Fy_Cs(Fy_x) = left(Fy_a(Fy_x),instr(Fy_a(Fy_x),"=")-1)

Next

For Fy_x=0 to ubound(Fy_Cs)

If Fy_Cs(Fy_x)<>"" Then

If Instr(LCase(Request(Fy_Cs(Fy_x))),"'")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"and")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"select")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"update")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"chr")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"delete%20from")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),";")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"insert")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"mid")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"master.")<>0 Then

select Case Fy_Cl

Case "1"

Response.Write "<Script Language=JavaScript>alert('出现错误!参数 "&Fy_Cs(Fy_x)&" 的值中包含非法字符串!\n\n 漏洞修复-miko QQ:9918097');window.close();</Script>"

Case "2"

Response.Write "<Script Language=JavaScript>location.href='"&Fy_Zx&"'</Script>"

Case "3"

Response.Write "<Script Language=JavaScript>alert('出现错误!参数 "&Fy_Cs(Fy_x)&"的值中包含非法字符串!\n\n 漏洞修复-miko QQ:9918097');location.href='"&Fy_Zx&"';</Script>"

End select

Response.End

End If

End If

Next

%>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: