ssdt函数索引号_一个获取系统服务索引号的小工具

这篇博客介绍了如何使用VC进行编译,并通过示例代码展示了获取NTDLL库中函数地址的过程,包括使用GetModuleHandle和GetProcAddress函数。博主分享了简单的代码实现,适合初学者了解系统调用和函数地址查找。
摘要由CSDN通过智能技术生成

好久没写博客了,最近想抽点时间补上之前的东西,有些东西要记录下来,以后看了会觉得很有意思。

这个小工具没有什么可以说的,直接vc编译连接就可以用了。下面附上代码:

#include "stdio.h"

#include

int main()

{

printf("请输入要获得索引号的函数的名称:\n");

CHAR apiName[256];

scanf("%s",apiName);

//获得函数地址

FARPROC pAddress1 = GetProcAddress(GetModuleHandle("ntdll"),(const char*)apiName);

printf("[%s]地址:%X \n",apiName,pAddress1);

//转换成PULONG

PULONG pAddress2 = (PULONG)pAddress1;

//kd> u ntdll!NtCreateFile

//ntdll!NtCreateFile:

//772555c8 b842000000 mov eax,42h

//772555cd ba0003fe7f mov edx,offset SharedUserData!SystemCallStub (7ffe0300)

//772555d2 ff12 call dword ptr [edx]

//772555d4 c22c00 ret 2Ch

//772555d7 90 nop

//(ULONG)pAddress2+1,b8汇编指令为一个字节所以要加1,然后重新转换地址指针

pAddress2 = (PULONG)((ULONG)pAddress2+1);

//*pAddress2表示获得此地址的内容,内容长度为4个字节

printf("[%s]在SSDT表中的索引:%X \n",apiName,*pAddress2);

system("PAUSE");

return 0;

}

其实短短几行代码,但本菜鸟觉得还是挺好用的。呵呵

0_1316934991gtmS.gif

菜鸟言论仅供娱乐。

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2011-09-25 15:14

浏览 715

评论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值