想把kernel32.DLL导出函数翻译为Delphi函数

最近看到一篇老文章,说的是使用GetCommandLine获取远程进程的命令行。我用Delphi重新实现了一下

function GetSysFuncAddr(AFunc: Pointer): Integer;

begin

  asm

    mov eax, AFunc

    add eax, 2

    mov eax, [eax]

    mov eax, [eax]

    mov Result, eax

  end;

end;

 

procedure GetRemoteCommandLine(ABuf: PChar; APID: Integer);

var

         dwAddr, dwRead: DWORD;

  hProc: THandle;

begin

  dwAddr :=  GetSysFuncAddr(@GetCommandLine) + 7;

  dwAddr :=  $7dd75178 - dwAddr;

  dwAddr :=  $7dd70d2c - dwAddr;

  asm

    mov eax, dwAddr

    mov eax, [eax]

    add eax, 1

    mov eax, [eax]

    mov dwAddr, eax

  end;

  hProc := OpenProcess(PROCESS_VM_READ, False, APID);

  ReadProcessMemory(hProc, Pointer(dwAddr), @dwAddr, 4, dwRead);

  ReadProcessMemory(hProc, Pointer(dwAddr), ABuf, MAX_PATH, dwRead);

End;

 

procedure  test;

var

         buf: array [0..MAX_PATH] of Char;

begin

         GetRemoteCommandLine(@buf, 3556);

End;

原帖地址忘了,原理大概是每一个进程都会把命令行存于自己进程空间的特定位置,GetCommandLineA会从这个位置读取命令行。

当然,只知道这一点是不够的,因为我们不知道另一个进程的命令行存的位置。但是有一种办法可以获得这个地址,那就是使用GetCommandLineA,

GetCommandLineA在所有的进程里地址是一样的(kernel32.DLL中所有函数都有这个特点),因此只要读取远端进程的GetCommandLineA的地址,加上特定的偏移,

就可以获得命令行存储的地址。(说的比较随便,其实只要看一下GetCommandLineA就能明白了)

后来我反编译了几个kernel32.DLL的函数,发现这对于学习系统有很大的帮助,因此就萌生了将kernel32.DLL中的函数翻译为Delphi函数的想法,希望能够坚持下去。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值