• <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 大海 閱讀(1669) 評論(0)  編輯 收藏 引用 所屬分類: VC++

            久久精品国产99久久无毒不卡 | 狠狠综合久久综合中文88| 国产午夜福利精品久久2021| 久久免费的精品国产V∧| 72种姿势欧美久久久久大黄蕉| 久久精品国产一区| 国产精品久久久香蕉| 久久99精品久久只有精品| 久久精品国产亚洲av瑜伽| 亚洲AV无码1区2区久久| 国产精品九九久久免费视频 | 伊人久久久AV老熟妇色| 国产精品亚洲综合专区片高清久久久 | 久久人人爽人人澡人人高潮AV | 99热成人精品热久久669| 亚洲精品tv久久久久| 久久久久女人精品毛片| 欧美性大战久久久久久| 国产精品久久久久久久久鸭| 伊色综合久久之综合久久| 久久午夜电影网| 久久久精品人妻一区二区三区蜜桃| 国产国产成人久久精品| 久久精品国产亚洲综合色| 亚洲精品乱码久久久久久蜜桃不卡| 亚洲国产精品无码久久九九| 久久99热狠狠色精品一区| 久久天天躁狠狠躁夜夜96流白浆| 久久久久久久国产免费看| 国内精品久久久久久久亚洲| 久久精品中文騷妇女内射| 性做久久久久久久| 国产精品久久久久久久久软件| 久久久久久青草大香综合精品| 青青草国产精品久久| 成人免费网站久久久| 久久久精品国产sm调教网站| 久久久无码人妻精品无码| A级毛片无码久久精品免费| 久久人爽人人爽人人片AV| 久久青青草原亚洲av无码app|