• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
            簡(jiǎn)單、開放、平等的公司文化;尊重個(gè)性、自由與個(gè)人價(jià)值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            監(jiān)控Explorer的進(jìn)程創(chuàng)建問題

            上一篇 / 下一篇 ?2008-08-23 14:50:57

            近日筆者收到某網(wǎng)友的信件稱,“為何自己寫的監(jiān)控 Explorer進(jìn)程代碼運(yùn)行后,系統(tǒng)會(huì)崩潰。”現(xiàn)筆者就這一問題,拿出與用戶共同探討。NT 下的 Explorer 通過 CreateProcessInternalW建立,R3的控制權(quán)。代碼如下:

            ????? bInheritHandles,
              DWORD?dwCreationFlags,
              LPVOID?lpEnvironment,
              LPCWSTR?lpCurrentDirectory,
              LPSTARTUPINFOW?lpStartupInfo,
              LPPROCESS_INFORMATION?lpProcessInformation,
              PHANDLE?hNewToken);
              int?APIENTRY?DllMain(HINSTANCE?hInstance,?DWORD?dwReason,?LPVOID?lpReserved)
              {
              UNREFERENCED_PARAMETER(lpReserved);
              if?(dwReason?==?DLL_PROCESS_ATTACH)
              {
              ExampleJmp();
              }
              else?if?(dwReason?==?DLL_PROCESS_DETACH)
              {
              SetHookOff();
              }
              return?1;
              }
              void?HookOneAPI(LPCTSTR?ModuleName,?LPCTSTR?ApiName,?FARPROC?lpNewFunc)
              {
              BYTE?str[8]?=?{?0x0B8,?0x0,?0x0,?0x40,?0x0,?0x0FF,?0x0E0,0};?//?mov?eax,addr?jmp?eax
              memcpy(m_NewFunc,str,8);
              m_lpHookFunc?=?GetProcAddress(GetModuleHandle(ModuleName),ApiName);
              m_hProc?=?GetCurrentProcess();
              memcpy(m_OldFunc,(char?*)m_lpHookFunc,8);
              *(DWORD?*)(?m_NewFunc?+?1?)?=?(DWORD)lpNewFunc;
              }
              void?WINAPI?SetHookOn()
              {
              MEMORY_BASIC_INFORMATION?mbi;
              VirtualQuery(m_lpHookFunc,&mbi,sizeof(mbi));
              VirtualProtect(m_lpHookFunc,sizeof(DWORD),PAGE_READWRITE,0);
              DWORD?dwOldFlag;
              WriteProcessMemory(m_hProc,?(void?*)m_lpHookFunc,
              (void?*)m_NewFunc,?8,&dwOldFlag);
              }
              void?WINAPI?SetHookOff()
              {
              DWORD?dwOldFlag;
              WriteProcessMemory(m_hProc,?(void?*)m_lpHookFunc,
              (void?*)m_OldFunc,?8,?&dwOldFlag);
              }
              BOOL?WINAPI?MyCreateProcess(HANDLE?hToken,
              LPCWSTR?lpApplicationName,
              LPWSTR?lpCommandLine,
              LPSECURITY_ATTRIBUTES?lpProcessAttributes,
              LPSECURITY_ATTRIBUTES?lpThreadAttributes,
              BOOL?bInheritHandles,
              DWORD?dwCreationFlags,
              LPVOID?lpEnvironment,
              LPCWSTR?lpCurrentDirectory,
              LPSTARTUPINFOW?lpStartupInfo,
              LPPROCESS_INFORMATION?lpProcessInformation,
              PHANDLE?hNewToken)
              {
              BOOL?BReturn=TRUE;
              SetHookOff();
              CreateProcessHH?CreateProcessHHH=(CreateProcessHH)GetProcAddress(GetModuleHandle("Kernel32.dll"),"CreateProcessInternalW");
              BReturn=CreateProcessHHH(hToken,lpApplicationName,lpCommandLine,lpProcessAttributes
              ,lpThreadAttributes,bInheritHandles,dwCreationFlags,lpEnvironment,lpCurrentDirectory,
              lpStartupInfo,lpProcessInformation,hNewToken);
              SetHookOn();
              return?BReturn;
              }
              BOOL?UpPrivilege(HANDLE?hprocess,LPCTSTR?lpname)?//提升進(jìn)程權(quán)限?debug
              {
              HANDLE?hToken;
              TOKEN_PRIVILEGES?Privileges;
              LUID?luid;
              OpenProcessToken(hprocess,TOKEN_ADJUST_PRIVILEGES,&hToken);
              Privileges.PrivilegeCount=1;
              LookupPrivilegeValue(NULL,lpname,&luid);
              Privileges.Privileges[0].Luid=luid;
              Privileges.Privileges[0].Attributes=SE_PRIVILEGE_ENABLED;
              if(AdjustTokenPrivileges(hToken,FALSE,&Privileges,NULL,NULL,NULL)!=0)
              return?TRUE;
              return?FALSE;
              }
              void?WINAPI?ExampleJmp()
              {
              char?privilege[]=SE_DEBUG_NAME;
              HANDLE?hprocess;
              hprocess=GetCurrentProcess();
              if(!UpPrivilege(hprocess,privilege))?//開始提權(quán)
              {
              exit(-1);
              }
              HookOneAPI("Kernel32.dll","CreateProcessInternalW",(FARPROC)MyCreateProcess);
              SetHookOn();
              }

            ????? 歡迎大家把自己的意見和代碼公布出來,IT專家網(wǎng)將給您和您的團(tuán)隊(duì)提供更多展現(xiàn)自己的舞臺(tái)!

            久久丝袜精品中文字幕| A级毛片无码久久精品免费| 一级做a爰片久久毛片免费陪| 少妇久久久久久被弄到高潮| 伊人久久大香线蕉综合热线| 亚洲精品乱码久久久久66| 青草国产精品久久久久久| 伊人久久免费视频| 久久久久女教师免费一区| 精产国品久久一二三产区区别| 久久精品国产精品亚洲毛片 | 久久久久久久久久久免费精品| 曰曰摸天天摸人人看久久久| 午夜肉伦伦影院久久精品免费看国产一区二区三区| 欧美亚洲国产精品久久久久| 无码人妻精品一区二区三区久久| 国产精品久久久久影院色| 欧美精品丝袜久久久中文字幕| 久久精品天天中文字幕人妻| 色偷偷88欧美精品久久久| 色综合久久久久无码专区| 久久久久久A亚洲欧洲AV冫| 99久久精品国产高清一区二区| 性高湖久久久久久久久AAAAA| 国产精品18久久久久久vr| 亚洲精品乱码久久久久久久久久久久 | av午夜福利一片免费看久久| 天天做夜夜做久久做狠狠| 亚洲国产成人久久精品影视| 浪潮AV色综合久久天堂| 狠狠色丁香久久婷婷综合蜜芽五月 | 国产精品成人99久久久久91gav| 青草国产精品久久久久久| 久久婷婷色综合一区二区| 久久国产福利免费| 久久精品三级视频| 久久久久国产视频电影| 美女久久久久久| 久久久久亚洲精品日久生情| 久久精品国产国产精品四凭| 久久久久亚洲AV无码去区首|