• SQL注入攻击


    SQL注入多见于动态SQL,利用拼接SQL的不安全性,在用户输入时输入特定的字符串、已到达非正常的目的。

    举个最简单的例子,假设没有一定的安全意识,客户端用一下VB代码构造查询和验证用户身份


    Visual Basic code12 sql=" select count(*) as cnt from dbo.users where usernmae='"_ & InputUserName & "' and pass'" & InputPass "';"


    正常的用户user1在输入框内输入
    InputUserName ='user1'
    InputPass='123'
    代码构造成下面的查询返回行数结果1.

    SQL code1 select count(*) as cnt from dbo.users where usernmae='user1' and pass='123'

    返回结果>0,则允许用户登陆。

    sql注入示例,在输入框输入
    InputUserName ="' or 1=1 --"
    InputPass= ""
    VB代码将构造成:

    SQL code1 select count(*) as cnt from dbo.users where usernmae='' or 1=1 --'and pass= '';

    注入原理是关闭了用户名前面开始的引号,添加表达式1=1,破折号'--'注释后面其余部分代码。这样返回的结果总是会大于0.那么就可以正常登陆系统了。
    还可以用户名输入框内输入
    "' or 1=1 drop database <db_name>--"
    --或者
    "'or 1=1 EXEC master.dbo.xp_cmdshell"format d:"--"


    SQL注入多见于动态SQL,利用拼接SQL的不安全性,在用户输入时输入特定的字符串、已到达非正常的目的。

    举个最简单的例子,假设没有一定的安全意识,客户端用一下VB代码构造查询和验证用户身份


    Visual Basic code12 sql=" select count(*) as cnt from dbo.users where usernmae='"_ & InputUserName & "' and pass'" & InputPass "';"


    正常的用户user1在输入框内输入
    InputUserName ='user1'
    InputPass='123'
    代码构造成下面的查询返回行数结果1.

    SQL code1 select count(*) as cnt from dbo.users where usernmae='user1' and pass='123'

    返回结果>0,则允许用户登陆。

    sql注入示例,在输入框输入
    InputUserName ="' or 1=1 --"
    InputPass= ""
    VB代码将构造成:

    SQL code1 select count(*) as cnt from dbo.users where usernmae='' or 1=1 --'and pass= '';

    注入原理是关闭了用户名前面开始的引号,添加表达式1=1,破折号'--'注释后面其余部分代码。这样返回的结果总是会大于0.那么就可以正常登陆系统了。
    还可以用户名输入框内输入
    "' or 1=1 drop database <db_name>--"
    --或者
    "'or 1=1 EXEC master.dbo.xp_cmdshell"format d:"--"

  • 相关阅读:
    [原创]ASP.NET MVC调用美图秀秀开放平台拼图实现
    使用Lucene检索文档中的关键字
    Unitils+hibernate+Spring+PostgreSql做dao层测试遇到的错误
    初探IronJS
    IntelliJ IDEA 12 创建Web项目 教程 超详细版
    百度面试题:求绝对值最小的数
    jquery+css实现简单的评分功能
    Knockot JS 数字输入插件
    Diagnostic Policy Service 服务处于起不来
    WCF学习笔记(一) 之 开门见山
  • 原文地址:https://www.cnblogs.com/tianliang/p/3117104.html
Copyright © 2020-2023  润新知