易语言资源网 - 做最全的易语言资源下载社区
精易论坛授权登录

【ntdll】LdrSetDllManifestProber回调Dll加载   [复制链接]

    2022-02-09 17:29:42
    模块控件源码
    易语言资源网
    1651 次浏览
    来源链接

ntdll.dll!LdrSetDllManifestProber,我相信很多人听都没有听说过这个命令,实际上,我们用这个命令只是为了干一件事:替换LdrpManifestProberRoutine。

在系统初始化DllMain的时候(本质上是走到LdrpWalkImportDescriptor的时候),它会检查LdrpManifestProberRoutine是否有效,然后调用LdrpManifestProberRoutine,对此部分的预原注释是: Probe the DLL for its manifest. Some details are omitted(探测 DLL 的清单。 省略了一些细节

LdrSetDllManifestProber是直接将LdrpManifestProberRoutine替换为我们的子程序,当调用LdrpWalkImportDescriptor时,便会触发回调,如图: 

LdrpManifestProberRoutine原来的代码比较复杂(它原来的地址是BasepProbeForDllManifest),实际上这个命令原来的操作是调用RtlCreateActivationContext来Create the activation context。我测试了一下,没有成功复现BasepProbeForDllManifest,现在的例子可能会造成程序不稳定,就这样了吧!大佬拿去玩吧。

虽然都是实现Dll加载回调,但是这个的实现原理和LdrRegisterDllNotification有本质上的区别,具体我不展开说了,自己去了解吧!



点我下载 (已有 23 次下载)

引用模块





引用支持库


源码文件名 支持库文件名 支持库标识
LdrSetDllManifestProber.e 系统核心支持库 5.7 d09f2340818511d396f6aaf844c7e325
辅助调试支持库 1.5 {A00B8D30-A5AB-4dfe-9546-9E636E711B75}


[错误报告]   上一篇:PHP+SQL+易语言 整合了很多常用功...     下一篇:简单的Excel模块源码, 使用易语言自...