Pwntools 的详细介绍、安装指南、配置说明
Pwntools:Python 开源安全工具箱
一、Pwntools 简介
Pwntools 是一个由 Security researcher 开发的 高效 Python 工具库,专为密码学研究、漏洞利用、协议分析和逆向工程设计。它集成了数百个底层工具的功能,提供统一的 Python API 接口,广泛用于 CTF竞赛、渗透测试和安全开发。其核心优势包括:
- 模块化设计:支持密码学、网络协议、shellcode生成等全栈操作
- 跨平台支持:兼容 Linux/macOS/Windows 系统
- 自动补丁生成:简化漏洞利用流程
- 社区驱动:持续更新漏洞利用模块和密码学算法
二、安装指南
1. 系统要求
| 操作系统 | 版本要求 | 依赖库 |
|---|---|---|
| Linux | Ubuntu 20.04+/Debian 11+ | Python3、pip、libssl-dev |
| Windows | 10/11 (64位) | Python3、pip、Visual C++ Redistributable |
| macOS | 10.15+ | Python3、pip、Xcode Command Line Tools |
2. 安装步骤
Linux/macOS
# 使用 pip 安装最新稳定版
pip install pwntools# 验证安装
python3 -c "import pwn; print(pwn.__version__)"
Windows
# 下载预编译 Python 环境
https://www.python.org/downloads/# 安装依赖库
pip install pwntools
三、配置说明
1. 环境配置
使用虚拟环境(推荐)
# 创建虚拟环境
python3 -m venv pwn_env# 激活虚拟环境
source pwn_env/bin/activate# 安装 Pwntools
pip install pwntools
全局安装(Linux/macOS)
sudo pip3 install pwntools
2. 配置文件
创建 ~/.pwnrc 文件(Linux/macOS)或 %APPDATA%\pwnrc 文件(Windows),设置常用参数:
# 示例配置:默认输出格式
setwarnings(0)
setlog(2) # 启用调试日志
四、基本使用示例
1. 密码学工具
MD5 哈希破解(字典攻击)
from pwn import *# 加载字典文件
password = "password123"
hash_value = hashlib.md5(password.encode()).hexdigest()# 使用 Aircrack-ng 样式的破解工具
cracker = BruteForceMD5()
cracker.add_words_from_file("dictionary.txt")if crackercracked(cracker, hash_value):print(f"Found password: {password}")
else:print("Password not found")
2. 漏洞利用
栈溢出漏洞利用(ROP链构造)
from pwn import *# 设置进程上下文
context(arch='amd64', os='linux')# 构造 ROP 链
rop = ROP(elf)
rop.find_gadget(['pop rdi', 'ret'])# 计算偏移量
offset = 40
payload = b'a' * offset + rop.chain(rop.read(0x601000, 8), rop.exit())# 注入并执行
io = process('./vulnerable_program')
io.send(payload)
io.interactive()
3. 网络协议分析
HTTP 请求伪造
from pwn import *# 构造 HTTP 请求
request = ("POST /login HTTP/1.1\r\n""Host: example.com\r\n""Content-Length: 28\r\n""Content-Type: application/x-www-form-urlencoded\r\n""username=admin\r\n""password=secret\r\n""\r\n"
)# 发送请求并接收响应
io = socket.tcpconnect('example.com', 80)
io.send(request.encode())
response = io.recv(1024)
print(response.decode())
五、高级功能使用
1. 反汇编与调试
使用 Unicorn 引擎动态分析
from pwn import *# 初始化 Unicorn 引擎
mu = Unicorn()
mu.load(elf.object)# 设置断点
mu.hook(0x400500, lambda regs: print("Breakpoint hit!"))# 执行代码
mu.emulate(0x400500)
2. 协议解析
SMB 协议解析器
from pwn import *# 构造 SMB 协议数据包
smb = SMB()
smb.add_header('Command', 'NEGOTIATE')
smb.add_header('Version', 'NT LM 0.12')# 发送请求到 Samba 服务器
io = socket.tcpconnect('smb-server', 445)
io.send(smb.pack())
3. 自动化测试
使用 pwnlib 运行模糊测试
from pwn import *# 定义模糊测试参数
targets = [('input.txt', 0x8000),('another_input.txt', 0x10000)
]# 执行模糊测试
fuzzer = Fuzzer(targets)
fuzzer.start()
六、典型应用场景
案例:利用缓冲区溢出漏洞获取Shell
-
分析目标程序:
gdb ./vulnerable_program -q
(gdb) disas main
-
构造 Exploit:
from pwn import *# 计算 EIP 偏移量
offset = 32# 构造 ROP 链(sys.exit)
rop = ROP(elf)
rop.find_gadget(['pop rdi', 'call', 'exit'])# 构造 Payload
payload = b'a' * offset + rop.chain(rop.read(0x601000, 8), rop.exit())# 注入并执行
io = process('./vulnerable_program')
io.send(payload)
io.interactive()
https://github.com/pwntools/pwntools
https://github.com/pwntools/ctf-challenges
https://discord.gg/pwntools
总结:
Pwntools 是安全研究人员和开发者手中的高效工具库,无论是密码学研究、漏洞利用还是协议分析,都能显著提升工作效率。建议从基础模块入手,逐步掌握 ROP 构造、动态分析和协议解析等高级功能。在实际使用中,结合 Wireshark、Frida 等工具进行多维度分析,将极大增强攻击面覆盖能力。
相关文章:
Pwntools 的详细介绍、安装指南、配置说明
Pwntools:Python 开源安全工具箱 一、Pwntools 简介 Pwntools 是一个由 Security researcher 开发的 高效 Python 工具库,专为密码学研究、漏洞利用、协议分析和逆向工程设计。它集成了数百个底层工具的功能,提供统一的 Python API 接口&am…...
PLC(电力载波通信)网络机制介绍
1. 概述 1.1 什么是PLC 电力载波通讯即PLC,是英文Power line Carrier的简称。 电力载波是电力系统特有的通信方式,电力载波通讯是指利用现有电力线,通过载波方式将模拟或数字信号进行高速传输的技术。最大特点是不需要重新架设网络…...
Qt监控系统远程回放/录像文件远程下载/录像文件打上水印/批量多线程极速下载
一、前言说明 在做这个功能的时候,着实费了点心思,好在之前做ffmpeg加密解密的时候,已经打通了极速加密保存文件,主要就是之前的类中新增了进度提示信号,比如当前已经处理到哪个position位置,发个信号出来…...
自学微信小程序的第八天
DAY8 1、使用动画API即可完成动画效果的制作,先通过wx.createAnimation()方法获取Animation实例,然后调用Animation实例的方法实现动画效果。 表40:wx.createAnimation()方法的常用选项 选项 类型 说明 duration number 动画持续时间,单位为毫秒,默认值为400毫秒 timing…...
【java】@Transactional导致@DS注解切换数据源失效
最近业务中出现了多商户多租户的逻辑,所以需要分库,项目框架使用了mybatisplus所以我们自然而然的选择了同是baomidou开发的dynamic.datasource来实现多数据源的切换。在使用初期程序运行都很好,但之后发现在调用com.baomidou.mybatisplus.ex…...
003 SpringBoot集成Kafka操作
4.SpringBoot集成Kafka 文章目录 4.SpringBoot集成Kafka1.入门示例2.yml完整配置3.关键配置注释说明1. 生产者优化参数2. 消费者可靠性配置3. 监听器高级特性4. 安全认证配置 4.配置验证方法5.不同场景配置模板场景1:高吞吐日志收集场景2:金融级事务消息…...
Android SystemUI开发(一)
frameworks/base/packages/SystemUI/src/com/android/systemui/SystemUI.java frameworks/base/packages/SystemUI/src/com/android/systemui/SystemUIService.java 关键文件 SystemUI 关键服务 简介 Dependency.class:处理系统依赖关系,提供资源或服…...
C#贪心算法
贪心算法:生活与代码中的 “最优选择大师” 在生活里,我们常常面临各种选择,都希望能做出最有利的决策。比如在超市大促销时,面对琳琅满目的商品,你总想用有限的预算买到价值最高的东西。贪心算法,就像是一…...
Vue程序下载
Vue是一个基于JavaScript(JS)实现的框架,想要使用它,就得先拿到Vue的js文件 Vue官网 Vue2:Vue.js Vue3:Vue.js - 渐进式 JavaScript 框架 | Vue.js 下载并安装vue.js 第一步:打开Vue2官网&a…...
【UCB CS 61B SP24】Lecture 17 - Data Structures 3: B-Trees学习笔记
本文以 2-3-4 树详细讲解了 B 树的概念,逐步分析其操作,并用 Java 实现了标准的 B 树。 1. 2-3 & 2-3-4 Trees 上一节课中讲到的二叉搜索树当数据是随机顺序插入的时候能够使得树变得比较茂密,如下图右侧所示,时间复杂度也就…...
机器学习决策树
一、香农公式 熵: 信息增益: 信息增益信息熵-条件熵 前者是初始信息熵大小,后者是因为条件加入后带来的确定性增加 信息增益表示得知特征X的信息而使得类Y的信息的不确定性减少的程度 信息增益越大说明影响越大 二、代码 ""&…...
Spring Boot + MyBatis 实现 RESTful API 的完整流程
后端开发:Spring Boot 快速开发实战 引言 在现代后端开发中,Spring Boot 因其轻量级、快速开发的特性而备受开发者青睐。本文将带你从零开始,使用 Spring Boot MyBatis 实现一个完整的 RESTful API,并深入探讨如何优雅地处理异…...
通过 ANSYS Discovery 进行 CFD 分析,增强工程设计
概括 工程师使用计算流体动力学 (CFD) 分析来研究和优化各种应用中的流体流动和传热分析。ANSYS Discovery 是一个用户友好的软件平台,使工程师能够轻松设置和解决 CFD 模型,并能够通知设计修改 在这篇博文中,我们将重点介绍在 Ansys Disc…...
家用可燃气体探测器——家庭燃气安全的坚实防线
随着社会的发展和变迁,天然气为我们的生活带来了诸多便利,无论是烹饪美食,还是温暖取暖,都离不开它的支持。然而,燃气安全隐患如影随形,一旦发生泄漏,可能引发爆炸、火灾等严重事故,…...
ListControl双击实现可编辑
为Edit Control控件添加丢失输入焦点事件,可见设为false 为List Control控件添加双击事件 控件和成员变量之间交换数据 CListCtrl ListPrint1; //列表输出 CEdit...
ave-form.vue 组件中 如何将产品名称发送给后端 ?
如何将产品名称发送给后端。 在这段代码中,产品名称(productName)的处理和发送主要发生在 save() 方法中。让我逐步分析: 产品ID的选择: <w-form-selectv-model"form.productId"label"涉及产品&q…...
DeepSeek行业应用实践报告-智灵动力【112页PPT全】
DeepSeek(深度搜索)近期引发广泛关注并成为众多企业/开发者争相接入的现象,主要源于其在技术突破、市场需求适配性及生态建设等方面的综合优势。以下是关键原因分析: 一、技术核心优势 开源与低成本 DeepSeek基于开源架构…...
【Markdown 语法简洁讲解】
Markdown 语法简洁语法讲解 什么是 Markdown1. 标题2. 列表3.文本样式4. 链接与图片5. 代码6. 表格7. 分割线8. 流程图9. 数学公式10. 快捷键11. 字体、字号与颜色 什么是 Markdown Markdown 是一种轻量级标记语言,通过简单的符号实现排版格式化,专注于…...
250301-OpenWebUI配置DeepSeek-火山方舟+硅基流动+联网搜索+推理显示
A. 最终效果 B. 火山方舟配置(一定要点击添加) C. 硅基流动配置(最好要点击添加,否则会自动弹出所有模型) D. 联网搜索配置 E. 推理过程显示 默认是没有下面的推理过程的显示的 设置步骤: 在Functions函…...
【3天快速入门WPF】12-MVVM
目录 1. 什么是MVVM2. 实现简单MVVM2.1. Part 12.2. Part 21. 什么是MVVM MVVM 是 Model-View-ViewModel 的缩写,是一种用于构建用户界面的设计模式,是一种简化用户界面的事件驱动编程方式。 MVVM 的目标是实现用户界面和业务逻辑之间的彻底分离,以便更好地管理和维护应用…...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...
【Go】3、Go语言进阶与依赖管理
前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课,做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程,它的核心机制是 Goroutine 协程、Channel 通道,并基于CSP(Communicating Sequential Processes࿰…...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...
SpringTask-03.入门案例
一.入门案例 启动类: package com.sky;import lombok.extern.slf4j.Slf4j; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCach…...
【JavaWeb】Docker项目部署
引言 之前学习了Linux操作系统的常见命令,在Linux上安装软件,以及如何在Linux上部署一个单体项目,大多数同学都会有相同的感受,那就是麻烦。 核心体现在三点: 命令太多了,记不住 软件安装包名字复杂&…...
NPOI操作EXCEL文件 ——CAD C# 二次开发
缺点:dll.版本容易加载错误。CAD加载插件时,没有加载所有类库。插件运行过程中用到某个类库,会从CAD的安装目录找,找不到就报错了。 【方案2】让CAD在加载过程中把类库加载到内存 【方案3】是发现缺少了哪个库,就用插件程序加载进…...
深入理解Optional:处理空指针异常
1. 使用Optional处理可能为空的集合 在Java开发中,集合判空是一个常见但容易出错的场景。传统方式虽然可行,但存在一些潜在问题: // 传统判空方式 if (!CollectionUtils.isEmpty(userInfoList)) {for (UserInfo userInfo : userInfoList) {…...
【Linux】自动化构建-Make/Makefile
前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具:make/makfile 1.背景 在一个工程中源文件不计其数,其按类型、功能、模块分别放在若干个目录中,mak…...
xmind转换为markdown
文章目录 解锁思维导图新姿势:将XMind转为结构化Markdown 一、认识Xmind结构二、核心转换流程详解1.解压XMind文件(ZIP处理)2.解析JSON数据结构3:递归转换树形结构4:Markdown层级生成逻辑 三、完整代码 解锁思维导图新…...
2025年- H71-Lc179--39.组合总和(回溯,组合)--Java版
1.题目描述 2.思路 当前的元素可以重复使用。 (1)确定回溯算法函数的参数和返回值(一般是void类型) (2)因为是用递归实现的,所以我们要确定终止条件 (3)单层搜索逻辑 二…...
