日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

DLL内存加载

發布時間:2025/6/17 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 DLL内存加载 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
動態加載dll
功能:
? ? ?把一個處于內存里的dll直接加載并且使用。
用途:
? ? ?免殺(靜態文件查殺),外掛(防止游戲自己hook了loadlibrary等函數),以及其他。
原理:?
? ? 假設目前處于內存里的dll是A,然后開辟一個新的內存空間B,根據A的文件頭等相關信息,把B看做是加載內存。
然后把數據拷貝到B里,并且對齊相關節,然后修正iat等相關。然后在手動調用一次dllmain函數,這樣dll就被從內存A
加載到內存B里了。之后再調用函數的時候,直接根據函數名,在INT或者其他位置找到函數地址,這個過程就是模擬了
GetProcAddress函數的功能。

整理了一個內存加載dll相關的類以及測試項目代碼:(http://download.csdn.net/detail/u013761036/9686863)
下面是相關測試代碼:

#include "stdafx.h" #include <string> #include <windows.h> #include <shlwapi.h> #include "MemLoadDll.h" #pragma comment(lib, "shlwapi.lib") using namespace std; #pragma warning(disable : 4996)unsigned char bMemory[1024*1024*5] = {0};DWORD dwLoadDll2Memory(string strDllPath){FILE *fpLoadDll; char cCache[1024]; if((fpLoadDll = fopen(strDllPath.c_str(),"rb")) == NULL) { return 0;} DWORD dwNowReadId = 0;while (1) { ZeroMemory(cCache ,sizeof(cCache));DWORD dwReadSize = fread(cCache,1,1024 ,fpLoadDll);DWORD dwErrorCode = GetLastError();if(dwReadSize == 0){break;}for(int i = 1 ;i <= dwReadSize ;i ++){bMemory[dwNowReadId++] = cCache[i-1];}} fclose(fpLoadDll); return dwNowReadId; }VOID SetCurrentDir(){WCHAR wcLocalPath[MAX_PATH*2] = {0};GetModuleFileName(0 ,wcLocalPath ,MAX_PATH);PathRemoveFileSpec(wcLocalPath);SetCurrentDirectory(wcLocalPath); }int _tmain(int argc, _TCHAR* argv[]) { //mark : After loading a function related to the memory will be released, that is, only one function can be loaded to performSetCurrentDir();DWORD dwFileLength = dwLoadDll2Memory("TestDll.dll");CMemLoadDll *clLoadClass = new CMemLoadDll();BOOL bLoadDllResult = clLoadClass->MemLoadLibrary(bMemory ,dwFileLength); if(bLoadDllResult){typedef VOID (*TYPEPRINTFMSE)(const string &strMessage);TYPEPRINTFMSE _PrintfMse = (TYPEPRINTFMSE)clLoadClass->MemGetProcAddress("PrintfMse");if(_PrintfMse){_PrintfMse("Memory load function executed successfully!");}else{// getprocaddress error}}else{//loadlibrary error}delete clLoadClass;return 0; }



總結

以上是生活随笔為你收集整理的DLL内存加载的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。