a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C > 正文

C語言內嵌匯編API內存搜索引擎實例

2020-01-26 15:12:10
字體:
來源:轉載
供稿:網友

本文實例講述了C語言內嵌匯編API內存搜索引擎的方法,分享給大家供大家參考。具體實現方法如下:

復制代碼 代碼如下:
// apisearchEngine.cpp : Defines the entry point for the console application. 
// 
 
#include "stdafx.h" 
#include <Windows.h> 
 
 DWORD __stdcall GetStrLengthA(char* szName) 

    _asm 
    { 
        push edi 
        push ebx 
        mov eax,  szName 
        mov edi, eax 
        mov ebx, eax 
        xor al, al 
 
lstrscan: 
        scas byte ptr [edi]          //字符掃描法檢查字符串指針長度  
        jnz lstrscan 
        dec edi 
        sub edi, ebx 
        mov eax, edi 
        pop ebx 
        pop edi 
         
    } 

 
 DWORD __stdcall CalcBufferCRC(char* lpBuffer) 

    _asm 
    { 
        push ebx 
        push edi 
        push ecx 
        push ebp 
        mov ebx, lpBuffer 
        push ebx 
        call GetStrLengthA 
        mov edi, eax 
        shr edi, 2 
        xor ecx, ecx 
loopBegin: 
        dec edi 
        jl loopOver 
        xor ecx, dword ptr [ebx] 
        add ebx, 4 
        jmp loopBegin 
loopOver: 
        mov eax, ecx 
        pop ebp 
        pop ecx 
        pop edi 
        pop ebx 
    } 

 
DWORD __stdcall GetProcAddressA(HANDLE hModule, DWORD dwExportCRC) 

    //DWORD lpProcNameCRC = ; 
    DWORD dwProcNumber; 
    LPVOID pProcAddress, pProcNameAddress, pProcIndexAddress; 
    _asm 
    { 
        push ebx 
        push esi 
         
        mov eax, hModule 
        mov edx,dwExportCRC      // edx=函數名CRC32 
        mov ebx, eax                // ebx=基址 
        mov eax, [ebx+0x3c]          // eax=文件頭偏移 
        mov esi, [ebx+eax+0x78]      // esi=輸出表偏移,文件頭+可選頭的長度=$78 
        lea esi, [ebx+esi+0x18]      // esi=函數名數量 = 函數數量 [ebx+esi+$14] 
        lods dword ptr ds:[esi] 
        mov dwProcNumber, eax       // eax=函數名數量 
        lods dword ptr ds:[esi] 
        mov pProcAddress, eax       // eax=函數偏移量 
        lods dword ptr ds:[esi] 
        mov pProcNameAddress, eax   // eax=函數名偏移量 
        lods dword ptr ds:[esi] 
        mov pProcIndexAddress, eax  // eax=序列號偏移量 
        mov edx, dwProcNumber       // edx=遍歷次數 
LoopBegin: 
        xor eax, eax                // Result = 0 
        dec edx 
        jl LoopEnd 
        mov eax, pProcNameAddress 
        add eax, ebx                // eax=函數名基地址 
        mov eax, dword ptr ds:[eax+edx*4] 
        add eax, ebx                // eax=遍歷函數名 
        push eax 
        call CalcBufferCRC 
        cmp eax, dwExportCRC      // 對比CRC32 
        jnz LoopBegin 
        shl edx, 1 
        add edx, pProcIndexAddress  // 函數基序列 
        movzx eax, word ptr ss:[edx+ebx] 
        shl eax, 2 
        add eax, pProcAddress       // 函數基地址 
        mov eax, [eax+ebx] 
        add eax, ebx                // Result = 函數地址 
LoopEnd: 
        pop esi 
        pop ebx 
         
    } 

DWORD __stdcall GetKernel32Module() 

    _asm 
    { 
        PUSH    EBP 
        XOR     ECX, ECX 
        //MOV     ESI, [FS:ECX + 0x30]        ; ESI = &(PEB) ([FS:0x30])
        MOV     ESI, FS:[0X30] 
        MOV     ESI, [ESI + 0x0C]           ; ESI = PEB->Ldr     
        MOV     ESI, [ESI + 0x1C]           ; ESI = PEB->Ldr.InInitOrder
next_module:     
        MOV     EBP, [ESI + 0x08]           ; EBP = InInitOrder[X].base_address     
        MOV     EDI, [ESI + 0x20]           ; EBP = InInitOrder[X].module_name (unicode)    
        MOV     ESI, [ESI]                  ; ESI = InInitOrder[X].flink (next module)     
        CMP     [EDI + 12*2], CL            ; modulename[12] == 0 ?     
        JNE     next_module                 ; No: try next module. 
        MOV     EAX, EBP 
        POP     EBP 
    } 

int main(int argc, char* argv[]) 

    printf("write by xiaoju !/n"); 
    printf("*****************/n"); 
    DWORD dwBaseKernel32 = GetKernel32Module(); 
    printf("Kernel32的模塊地址:%08x/n",dwBaseKernel32); 
 
    DWORD LoadLibraryCRC32= CalcBufferCRC("LoadLibraryA") ; 
    printf("LoadLibraryA的CRC值(靜態寫到程序中):%08x/n/n", LoadLibraryCRC32); 
     
    DWORD dwAddrLoadLibrary = GetProcAddressA((HANDLE)dwBaseKernel32, 0x577a7461);  
    printf("在程序中動態得到的LoadLibraryA的地址:%08x/n", dwAddrLoadLibrary); 
    getchar(); 
    return 0; 
}

希望本文所述對大家的C程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 日韩三级在线 | 久久久精 | 中文字幕精品一区久久久久 | 国产剧情一区二区三区 | 欧美日韩一区二区中文字幕 | 国产91亚洲精品 | 精品视频 免费 | 综合二区| 成人免费观看在线视频 | 精品亚洲一区二区三区 | 日韩精品一区二区三区在线 | 韩国三级中文字幕hd爱的色放 | 可以看黄色的网站 | 亚洲电影免费 | 91在线最新 | 涩涩av| 国产精品久久久久免费a∨ 国产激情一区二区三区 | 国产欧美一区二区精品性色 | 国产一区二区在线看 | 中文一区 | 国产欧美精品一区二区三区 | 亚洲国产成人久久综合一区,久久久国产99 | 日韩欧美不卡 | 欧美午夜视频 | 国产精品成人一区二区三区 | 久久毛片 | www.亚洲 | 热久久国产 | 一区二区三区免费 | 国产精品久久久久久亚洲毛片 | 91精品国产一区二区三区蜜臀 | 蜜桃久久久久久 | 久久精品国产一区二区电影 | 一本一道久久a久久精品综合蜜臀 | 精品三级在线观看 | 少妇久久久 | 亚洲精品一区二区三区蜜桃久 | 亚洲成人精品在线 | 日韩av电影在线播放 | 中文字幕婷婷 | 欧美日韩精品一区二区 |