error at hooking api ntprotect_read,match and write

error at hooking api ntprotect_read,match and write 编译环境:delphi2010+windows7u,用途读取其他程序中readprocessmemory和writeprocessmemory的参数,但不知读取偏移即a+($b),b是怎么读的  一、用hook全局钩子线程钩子:已实现使用INLINEhookapi,CriticalSection临界区,dll分为动态loadlibry和静态加载问题1:对多线程目标

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 编译环境:delphi 2010+windows 7 u ,用途读取其他程序中readprocessmemory和writeprocessmemory的参数,但不知读取偏移即a+($b),b是怎么读的

 

 一 、用hook全局钩子 线程钩子:已实现 使用INLINE hookapi,CriticalSection临界区,dll分为动态loadlibry和静态加载

问题1:对多线程目标程序HOOK 卸载时会出现错误,应该是线程不断读写内存函数READPROCESSMEMORY,但钩子正在卸载没有改回正确的地址就被目标程序读取,导致目标程序处理错误的API地址而出错,如果不是不停读写 卸载不会出现错误?不知是不是

问题2:使用INLINE HOOK目标程序多线程读取内存,程序在卸载钩子时有时会出错,可能跟问题一 一样。使用CreateRemoteThread远程注入是否会有此问题,应该没有吧!

问题3:自己的替代函数中使用记录日志可能不响应,为什么?

问题4:使用临界区后没出现EXPLORER的问题,也可能是逻辑代码问题,有待研究。

 

 

备注:

windows核心编程中的 IAT Hook 是否存在线程问题??

1 : Hook LoadLibrary*后, 若两线程同时调用LoadLibrary, 可能同时修改同一个模块的IAT表, 可能存在访问冲突(此问题可以用临界区解决)
2 : Hook LoadLibrary*后, 他对本进程所有模块的的IAT表都进行修改(使用WriteProcessMemory), 某线程可能此时访问正在被修改中的IAT表, 可能call 到其它地址去。(若真存在多线程问题, 此问题就有点麻烦)。似乎是说多线程下同时写入读写东西时,还没修复回IAI就被其他线程调用,程序会出错。

2009-10-0515:14:29

hook api

源码在此 !

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/194475.html原文链接:https://javaforall.net

(0)
上一篇 2025年11月5日 上午9:15
下一篇 2025年11月5日 上午9:43


相关推荐

  • 安装和使用PHP进程管理框架 QPM

    安装和使用PHP进程管理框架 QPMQPM 全名是 QuickProcess PHP 是强大的 web 开发语言 以至于大家常常忘记 PHP 可以用来开发健壮的命令行 CLI 程序以至于 daemon 程序 而编写 daemon 程序免不了与各种进程管理打交道 QPM 正式为简化进程管理而开发的类库 QPM 的项目地址是 https github com Comos qpm

    2026年3月18日
    1
  • Python Scrapy 安装及相关配置

    Python Scrapy 安装及相关配置本文仅供学习交流使用 如侵立删 联系方式及 demo 下载见文末 PythonScrapy 安装及相关配置环境 win10Python 3 6 7Scrapy 2 4 1Python 安装 Scrapy 安装 pipinstallsc 解决 Command pythonsetup pyegg info failedwither 问题更新 pippipinstal 问题 权限不足解决 pip

    2026年3月26日
    2
  • Linux下配置DNS服务

    Linux下配置DNS服务一 DNS 服务简介 DNS 服务器 也称为域名解析服务器 是用来将互联网上的域名解析为 IP 地址的一类服务器 在世界上有成百上千台 DNS 服务器 对于有些公司来说 对于同一个域名可能有多个 DNS 服务器 这样可以降低主域名服务器的负载 例如 baidu com 可能会存在多个 DNS 服务器 因为在同一时刻可能有成百上千台主机同时请求 baidu com 这个域名 如果只有一台 DNS

    2026年3月19日
    2
  • tcp为什么要三次握手,两次不行吗_tcp为什么不能二次握手

    tcp为什么要三次握手,两次不行吗_tcp为什么不能二次握手作者:大闲人柴毛毛链接:https://www.zhihu.com/question/24853633/answer/254224088来源:知乎著作权归作者所有。商业转载请联系作者获得授权,非商业转

    2022年8月2日
    7
  • matlab 二次函数图像「建议收藏」

    matlab 二次函数图像「建议收藏」二次函数图像clc,clear;holdonforx=-2:0.01:2y=x^2;plot(x,y,’c.’);end

    2025年9月25日
    8
  • 内核态和用户态的区别_会导致用户进程用户态到内核态

    内核态和用户态的区别_会导致用户进程用户态到内核态1、用户态和内核态的区别?明白这两个概念之前,我们得知道用户空间和内核空间。用户空间:指的就是用户可以操作和访问的空间,这个空间通常存放我们用户自己写的数据等。内核空间:是系统内核来操作的一块空间,这块空间里面存放系统内核的函数、接口等。在用户空间下执行,我们把此时运行得程序的这种状态成为用户态,而当这段程序执行在内核的空间执行时,这种状态称为内核态。当一个任务(进程)执行系统…

    2026年1月16日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号