Windows逆向工程入门之堆栈结构与信息获取
- 公开视频 -> 链接点击跳转公开课程
- 博客首页 -> 链接点击跳转博客主页
目录
1. 堆栈结构基础
堆栈的主要操作:
2. 代码功能解析
2.1 加载 ntdll.dll
2.2 获取 NtQueryInformationThread 函数指针
2.3 调用 NtQueryInformationThread 获取线程信息
2.4 获取线程环境块(TEB)
2.5 输出堆栈信息
3. 涉及的知识点拓展
3.1 线程环境块(TEB)
3.2 堆栈溢出与保护
3.3 Windows API 与逆向工程
3.4 调试与堆栈分析
1. 堆栈结构基础
堆栈(Stack)是一种后进先出(LIFO, Last In First Out)的数据结构,常用于函数调用、局部变量存储等场景。在程序运行中,堆栈用于管理函数调用、保存返回地址、存储局部变量以及维护程序执行的上下文。
堆栈的主要操作:
- 函数调用:调用函数时,当前函数的执行状态(如返回地址)会被压入堆栈。
- 栈底保存:栈底通常是固定的,用于标记堆栈的起始位置。
- 提升栈顶:函数调用时,栈顶会向上移动,用于分配新的空间。
- 保存数据:局部变量、返回地址等数据会被存储在堆栈中。
- 缓冲填充:堆栈有时会被填充特定的字节数据,用于对齐内存或防止溢出。
- 业务实现:实际的函数逻辑在堆栈分配的内存区域中操作。
- 恢复数据:函数返回时,堆栈中的数据会被恢复。
- 恢复栈顶:函数返回后,栈顶指针会返回到调用前的位置。
- 恢复栈底:栈底通常不变,标志堆栈的起点。
- 函数返回:从堆栈中弹出返回地址,恢复调用点继续执行。
- 堆栈平衡:确保函数调用前后堆栈的状态一致,避免内存泄漏或崩溃。
- 堆栈信息:通过调试或程序手段可以获取堆栈的基本信息,如栈底、栈顶、大小等。
2. 代码功能解析
上述代码展示了如何通过 Windows API 获取线程的堆栈信息,以下是分步骤解析:
2.1 加载 ntdll.dll
HMODULE hNtdll = LoadLibrary(L"ntdll.dll");
ntdll.dll 是 Windows 操作系统的一个核心动态链接库,提供底层的系统服务函数。加载该库后可以使用其导出的函数。
2.2 获取 NtQueryInformationThread 函数指针
PNtQueryInformationThread pFun = (PNtQueryInformationThread)GetProcAddress(hNtdll, "NtQueryInformationThread");
通过 GetProcAddress 获取 NtQueryInformationThread 函数的地址,该函数用于查询线程的详细信息。
2.3 调用 NtQueryInformationThread 获取线程信息
NTSTATUS status = pFun(GetCurrentThread(), (THREADINFOCLASS)0, &tbi, sizeof(THREAD_BASIC_INFORMATION), NULL);
调用 NtQueryInformationThread 获取当前线程的基本信息,存储在 THREAD_BASIC_INFORMATION tbi 结构中。
2.4 获取线程环境块(TEB)
PNT_TIB pTib = (PNT_TIB)tbi.TebBaseAddress;
通过 THREAD_BASIC_INFORMATION 中的 TebBaseAddress 字段获取线程的环境块(Thread Environment Block, TEB)。TEB 是一个结构体,包含线程的堆栈信息、异常处理信息等。
2.5 输出堆栈信息
std::cout << pTib->StackBase << std::endl; std::cout << pTib->StackLimit << std::endl;
通过 TEB 的 StackBase 和 StackLimit 字段获取堆栈的起始地址和结束地址。
3. 涉及的知识点拓展
3.1 线程环境块(TEB)
TEB 是 Windows 线程的核心数据结构,每个线程都有一个对应的 TEB,存储在线程的用户模式内存空间中。主要字段包括:
StackBase:堆栈的起始地址。StackLimit:堆栈的结束地址。Self:指向自身的指针。ExceptionList:异常处理链表。EnvironmentPointer:指向环境变量的指针。
3.2 堆栈溢出与保护
堆栈溢出是指程序在堆栈中写入超出其容量的数据,可能导致程序崩溃或被攻击者利用。为防止堆栈溢出,现代操作系统和编译器引入了以下机制:
- 栈保护(Stack Guard):在栈帧中插入一个保护值(Canary),函数返回时验证保护值是否被篡改。
- DEP(Data Execution Prevention):禁止堆栈中的数据被执行。
- ASLR(Address Space Layout Randomization):随机化堆栈地址,增加攻击难度。
3.3 Windows API 与逆向工程
在逆向工程中,了解 Windows API 的使用和底层实现是关键。NtQueryInformationThread 是一个常用的 API,用于获取线程的详细信息,逆向工程时通常用于分析线程堆栈、异常处理等。
3.4 调试与堆栈分析
调试工具(如 WinDbg、x64dbg)可以用来分析程序的堆栈信息,帮助理解程序的执行流程和查找问题。例如:
- 查看当前栈帧和调用链。
- 分析堆栈中存储的变量和返回地址。
- 检查堆栈溢出或未平衡的调用。
相关文章:
Windows逆向工程入门之堆栈结构与信息获取
公开视频 -> 链接点击跳转公开课程博客首页 -> 链接点击跳转博客主页 目录 1. 堆栈结构基础 堆栈的主要操作: 2. 代码功能解析 2.1 加载 ntdll.dll 2.2 获取 NtQueryInformationThread 函数指针 2.3 调用 NtQueryInformationThread 获取线程信息…...
【c++初阶】类和对象②默认成员函数以及运算符重载初识
目录 编辑 默认成员函数: 构造函数 构造函数的特性: 析构函数: 拷贝构造函数: 1. 拷贝构造函数是构造函数的一个重载形式。 2. 拷贝构造函数的参数只有一个且必须是类类型对象的引用,使用传值方式编译器直接报…...
【做一个微信小程序】校园地图页面实现
前言 上一个教程我们实现了小程序的一些的功能,有背景渐变色,发布功能有的呢,已支持图片上传功能,表情和投票功能开发中(请期待)。下面是一个更高级的微信小程序实现,包含以下功能:…...
成熟开发者需具备的能力
精业务 • 指深入理解和熟悉所开发软件的业务逻辑和需求。 • 开发者需要明确软件要解决的问题、面向的用户群体以及核心功能等。 • 精业务有助于开发者更好地设计系统架构、编写符合业务需求的代码,并能根据业务变化灵活调整开发计划。 懂原理 • 指掌握编程的基…...
计算机毕业设计--基于深度学习技术(Yolov11、v8、v7、v5)算法的高效人脸检测模型设计与实现(含Github代码+Web端在线体验界面)
基于深度学习技术(Yolov11、v8、v7、v5)算法的高效人脸检测模型 Yolo算法应用之《基于Yolo的花卉识别算法模型设计》,请参考这篇CSDN作品👇 计算机毕业设计–基于深度学习技术(Yolov11、v8、v7、v5)算法的…...
力扣做题记录 (二叉树)
二叉树 打算先来了解二叉树基础,都是简单题,目的是熟悉代码格式和解题基础思路。 1、二叉树最大深度 二叉树最大深度 方法一、深度搜索 直接用原函数做递归,比较简单 /*** Definition for a binary tree node.* struct TreeNode {* …...
机试刷题_字符串的排列【python】
题目:字符串的排列 from os import dup # # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # # param str string字符串 # return string字符串一维数组 # class Solution:def backtrack(self,res,state,choi…...
百度智能云—千帆 ModelBuilder API的简单调用(Java)
百度简介 百度(Baidu)是拥有强大互联网基础的领先AI公司。百度愿景是:成为最懂用户,并能帮助人们成长的全球顶级高科技公司。 “百度”二字,来自于八百年前南宋词人辛弃疾的一句词:众里寻他千百度。这句话…...
unity学习43:子状态机 sub-state machine
目录 1sub-state machine子状态机 1.1 创建 sub-state machine 1.2 sub-state machine 内容 1.3 子状态机的应用 2 子状态机不同于blend tree的嵌套 3 应用例子:若角色拿不同武器的动画设计,可以使用2种方法 3.1 在1个图层layer里,使用…...
Qt MainWindow
文章目录 0. 概述1. 菜单栏 QMenuBar1.1 例子1,使用图形化界面1.2 例子2,使用代码创建1.3 例子3,添加快捷键1.4 例子4,添加子菜单1.5 例子5,添加分割线和图标1.6 内存泄漏问题 2. 工具栏 QToolBar2.1 例子1,…...
GDB QUICK REFERENCE (GDB 快速参考手册)
GDB QUICK REFERENCE {GDB 快速参考手册} References GDB QUICK REFERENCE GDB Version 4 https://users.ece.utexas.edu/~adnan/gdb-refcard.pdf 查看方式:在新标签页中打开图片 References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/ [2] gdb-refc…...
【数据结构】 栈和队列
在计算机科学的世界里,数据结构是构建高效算法的基础。栈(Stack)和队列(Queue)作为两种基本且重要的数据结构,在软件开发、算法设计等众多领域都有着广泛的应用。今天,我们就来深入探讨一下栈和…...
AI视频创作教程:如何用AI让古画动起来。
事情缘由: 如果是简单的图,找原图直接写提示词即可。 如果碰到多人多活动的图,直接出的效果会很不好,那么该怎么做呢? 图片分模块 首先,复杂部分的图,把长图分多个模块。 比如这张图࿰…...
撕碎QT面具(1):Tab Widget转到某个Tab页
笔者未系统学过C语法,仅有Java基础,具体写法仿照于大模型以及其它博客。自我感觉,如果会一门对象语言,没必要先刻意学C,因为自己具有对象语言的基础,等需要用什么再学也不迟。毕竟不是专门学C去搞算法。 1…...
DeepSeek24小时写作机器人,持续创作高质量文案
内容创作已成为企业、自媒体和创作者的核心竞争力。面对海量的内容需求,人工创作效率低、成本高、质量参差不齐等问题日益凸显。如何在有限时间内产出高质量内容?DeepSeek写作机器人,一款24小时持续创作的智能工具,为企业和个人提…...
npm安装依赖(npm install)时遇到认证错误的解决方案
问题描述 在使用 npm install 安装依赖时遇到以下错误: npm error code E401 npm error Incorrect or missing password.解决方案 方案一:使用淘宝(或其它国内公共)镜像(如果已经是淘宝镜像跳过此步) 设…...
SpringBoot+微信小程序+数据可视化的宠物到家喂宠服务(程序+论文+讲解+安装+调试+售后等)
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,我会一一回复,希望帮助更多的人。 系统介绍 在经济高速发展、物质生活极大丰富的当下,人们的精神需求愈发凸显࿰…...
免费大模型网站
腾讯元宝 腾讯元宝 秘塔搜索 秘塔搜索 超算互联网 超算互联网回答速度很慢 Chatbot Arena Chatbot Arena 大模型竞技场。...
OpenCV的主要模块
OpenCV的模块...
使用 Python 爬虫和 FFmpeg 爬取 B 站高清视频
以下是一个完整的 Python 爬虫代码示例,用于爬取 B 站视频并使用 FFmpeg 合成高清视频。 1. 准备工作 确保安装了以下 Python 库和工具: bash复制 pip install requests moviepy2. 爬取视频和音频文件 B 站的视频和音频文件通常是分开存储的&#x…...
KubeSphere 容器平台高可用:环境搭建与可视化操作指南
Linux_k8s篇 欢迎来到Linux的世界,看笔记好好学多敲多打,每个人都是大神! 题目:KubeSphere 容器平台高可用:环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...
XML Group端口详解
在XML数据映射过程中,经常需要对数据进行分组聚合操作。例如,当处理包含多个物料明细的XML文件时,可能需要将相同物料号的明细归为一组,或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码,增加了开…...
大数据零基础学习day1之环境准备和大数据初步理解
学习大数据会使用到多台Linux服务器。 一、环境准备 1、VMware 基于VMware构建Linux虚拟机 是大数据从业者或者IT从业者的必备技能之一也是成本低廉的方案 所以VMware虚拟机方案是必须要学习的。 (1)设置网关 打开VMware虚拟机,点击编辑…...
在Ubuntu中设置开机自动运行(sudo)指令的指南
在Ubuntu系统中,有时需要在系统启动时自动执行某些命令,特别是需要 sudo权限的指令。为了实现这一功能,可以使用多种方法,包括编写Systemd服务、配置 rc.local文件或使用 cron任务计划。本文将详细介绍这些方法,并提供…...
第一篇:Agent2Agent (A2A) 协议——协作式人工智能的黎明
AI 领域的快速发展正在催生一个新时代,智能代理(agents)不再是孤立的个体,而是能够像一个数字团队一样协作。然而,当前 AI 生态系统的碎片化阻碍了这一愿景的实现,导致了“AI 巴别塔问题”——不同代理之间…...
uniapp中使用aixos 报错
问题: 在uniapp中使用aixos,运行后报如下错误: AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...
Python 包管理器 uv 介绍
Python 包管理器 uv 全面介绍 uv 是由 Astral(热门工具 Ruff 的开发者)推出的下一代高性能 Python 包管理器和构建工具,用 Rust 编写。它旨在解决传统工具(如 pip、virtualenv、pip-tools)的性能瓶颈,同时…...
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要: 近期,在使用较新版本的OpenSSH客户端连接老旧SSH服务器时,会遇到 "no matching key exchange method found", "n…...
C/C++ 中附加包含目录、附加库目录与附加依赖项详解
在 C/C 编程的编译和链接过程中,附加包含目录、附加库目录和附加依赖项是三个至关重要的设置,它们相互配合,确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中,这些概念容易让人混淆,但深入理解它们的作用和联…...
LLMs 系列实操科普(1)
写在前面: 本期内容我们继续 Andrej Karpathy 的《How I use LLMs》讲座内容,原视频时长 ~130 分钟,以实操演示主流的一些 LLMs 的使用,由于涉及到实操,实际上并不适合以文字整理,但还是决定尽量整理一份笔…...
