API函数调用:是先得到API函数代码地址的导入地址,再得到API函数代码地址,再执行代码
内部实现函数调用:是先调"内部实现函数"的"函数入口的静态表(@ILT)"的对应函数,再执行真正函数代码。
比如:
调MessageBoxA(NULL, "Test", "Test", MB_OK);执行汇编代码为:dword ptr [__imp__MessageBoxA@16 (0042b2cc)],0042b2cc实际上是MessageBoxA在导入函数的(unsigned *) RVA2Ptr(pIMAGE_IMPORT_DESCRIPTOR->FirstThunk)+i,实际上是API函数代码地址的导入地址
调自定义函数MyMessageBoxA(NULL, "Test", "Test", MB_OK);执行汇编代码为:
call @ILT+25(MyMessageBoxA) (0040101e),@ILT实际上是函数入口的静态表