• <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.¢%

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

            [Reference]獲取其它進程命令行

            Posted on 2008-10-23 21:26 S.l.e!ep.¢% 閱讀(679) 評論(0)  編輯 收藏 引用 所屬分類: VC

            //?? procmdline.cpp?? (Windows?? NT/2000)??
            //??
            //?? This?? example?? shows?? how?? to?? get?? the?? command?? line?? for?? almost?? any?? process??
            //?? on?? the?? system?? for?? Windows?? NT/2000??
            //????
            //??
            //?? (c)1999?? Ashot?? Oganesyan?? K,?? SmartLine,?? Inc??
            //?? mailto:ashot@aha.ru,?? http://www.protect-me.com,?? http://www.codepile.com??

            #include?? <windows.h>??
            #include?? <stdio.h>??

            #define?? ProcessBasicInformation?? 0??

            typedef?? struct??
            {??
            ?USHORT?? Length;??
            ?USHORT?? MaximumLength;??
            ?PWSTR???? Buffer;??
            }?? UNICODE_STRING,?? *PUNICODE_STRING;??

            typedef?? struct??
            {??
            ?ULONG???????????????????? AllocationSize;??
            ?ULONG???????????????????? ActualSize;??
            ?ULONG???????????????????? Flags;??
            ?ULONG???????????????????? Unknown1;??
            ?UNICODE_STRING?? Unknown2;??
            ?HANDLE?????????????????? InputHandle;??
            ?HANDLE?????????????????? OutputHandle;??
            ?HANDLE?????????????????? ErrorHandle;??
            ?UNICODE_STRING?? CurrentDirectory;??
            ?HANDLE?????????????????? CurrentDirectoryHandle;??
            ?UNICODE_STRING?? SearchPaths;??
            ?UNICODE_STRING?? ApplicationName;??
            ?UNICODE_STRING?? CommandLine;??
            ?PVOID???????????????????? EnvironmentBlock;??
            ?ULONG???????????????????? Unknown[9];??
            ?UNICODE_STRING?? Unknown3;??
            ?UNICODE_STRING?? Unknown4;??
            ?UNICODE_STRING?? Unknown5;??
            ?UNICODE_STRING?? Unknown6;??
            }?? PROCESS_PARAMETERS,?? *PPROCESS_PARAMETERS;??

            typedef?? struct??
            {??
            ?ULONG?????????????????????????????? AllocationSize;??
            ?ULONG?????????????????????????????? Unknown1;??
            ?HINSTANCE?????????????????????? ProcessHinstance;??
            ?PVOID?????????????????????????????? ListDlls;??
            ?PPROCESS_PARAMETERS?? ProcessParameters;??
            ?ULONG?????????????????????????????? Unknown2;??
            ?HANDLE???????????????????????????? Heap;??
            }?? PEB,?? *PPEB;??

            typedef?? struct??
            {??
            ?DWORD?? ExitStatus;??
            ?PPEB???? PebBaseAddress;??
            ?DWORD?? AffinityMask;??
            ?DWORD?? BasePriority;??
            ?ULONG?? UniqueProcessId;??
            ?ULONG?? InheritedFromUniqueProcessId;??
            }?????? PROCESS_BASIC_INFORMATION;??


            //?? ntdll!NtQueryInformationProcess?? (NT?? specific!)??
            //??
            //?? The?? function?? copies?? the?? process?? information?? of?? the??
            //?? specified?? type?? into?? a?? buffer??
            //??
            //?? NTSYSAPI??
            //?? NTSTATUS??
            //?? NTAPI??
            //?? NtQueryInformationProcess(??
            //???????? IN?? HANDLE?? ProcessHandle,???????????????????????????? //?? handle?? to?? process??
            //???????? IN?? PROCESSINFOCLASS?? InformationClass,?? //?? information?? type??
            //???????? OUT?? PVOID?? ProcessInformation,?????????????????? //?? pointer?? to?? buffer??
            //???????? IN?? ULONG?? ProcessInformationLength,???????? //?? buffer?? size?? in?? bytes??
            //???????? OUT?? PULONG?? ReturnLength?? OPTIONAL???????????? //?? pointer?? to?? a?? 32-bit??
            //???????????????????????????????????????????????????????????????????????????????????? //?? variable?? that?? receives??
            //???????????????????????????????????????????????????????????????????????????????????? //?? the?? number?? of?? bytes??
            //???????????????????????????????????????????????????????????????????????????????????? //?? written?? to?? the?? buffer????
            //?? );??
            typedef?? LONG?? (WINAPI?? *PROCNTQSIP)(HANDLE,UINT,PVOID,ULONG,PULONG);??


            PROCNTQSIP?? NtQueryInformationProcess;??

            BOOL?? GetProcessCmdLine(DWORD?? dwId,LPWSTR?? wBuf,DWORD?? dwBufLen);??

            void?? main(int?? argc,?? char*?? argv[])??
            {??
            ?if?? (argc<2)??
            ?{??
            ??printf("Usage:\n\ncmdline.exe?? ProcId\n");??
            ??return;??
            ?}??
            ?
            ?
            ?NtQueryInformationProcess?? =?? (PROCNTQSIP)GetProcAddress(??
            ??GetModuleHandle("ntdll"),??
            ??"NtQueryInformationProcess"??
            ??);??
            ???
            ?if?? (!NtQueryInformationProcess)??
            ??return;??
            ???
            ?DWORD?? dwId;??
            ?sscanf(argv[1],"%lu",&dwId);??
            ???
            ?WCHAR?? wstr[255];??
            ???
            ?if?? (GetProcessCmdLine(dwId,wstr,sizeof(wstr)))??
            ??wprintf(L"Command?? line?? for?? process?? %lu?? is:\n %s?? \n", dwId, wstr);??
            ?else??
            ??wprintf(L"Could?? not?? get?? command?? line!");??
            ???
            }??

            BOOL?? GetProcessCmdLine(DWORD?? dwId,LPWSTR?? wBuf,DWORD?? dwBufLen)??
            {??
            ?LONG???????????????????????????????????????????? status;??
            ?HANDLE???????????????????????????????????????? hProcess;??
            ?PROCESS_BASIC_INFORMATION?? pbi;??
            ?PEB?????????????????????????????????????????????? Peb;??
            ?PROCESS_PARAMETERS???????????????? ProcParam;??
            ?DWORD?????????????????????????????????????????? dwDummy;??
            ?DWORD?????????????????????????????????????????? dwSize;??
            ?LPVOID???????????????????????????????????????? lpAddress;??
            ?BOOL???????????????????????????????????????????? bRet?? =?? FALSE;??
            ???
            ?//?? Get?? process?? handle??
            ?hProcess?? =?? OpenProcess(PROCESS_QUERY_INFORMATION|PROCESS_VM_READ,FALSE,dwId);??
            ?if?? (!hProcess)??
            ??return?? FALSE;??
            ???
            ?//?? Retrieve?? information??
            ?status?? =?? NtQueryInformationProcess(?? hProcess,??
            ??ProcessBasicInformation,??
            ??(PVOID)&pbi,??
            ??sizeof(PROCESS_BASIC_INFORMATION),??
            ??NULL??
            ??);??
            ???
            ???
            ?if?? (status)??
            ??goto?? cleanup;??
            ???
            ?if?? (!ReadProcessMemory(?? hProcess,??
            ??pbi.PebBaseAddress,??
            ??&Peb,??
            ??sizeof(PEB),??
            ??&dwDummy??
            ??)??
            ??)??
            ??goto?? cleanup;??
            ???
            ?if?? (!ReadProcessMemory(?? hProcess,??
            ??Peb.ProcessParameters,??
            ??&ProcParam,??
            ??sizeof(PROCESS_PARAMETERS),??
            ??&dwDummy??
            ??)??
            ??)??
            ??goto?? cleanup;??
            ???
            ?lpAddress?? =?? ProcParam.CommandLine.Buffer;??
            ?dwSize?? =?? ProcParam.CommandLine.Length;??
            ???
            ?if?? (dwBufLen<dwSize)??
            ??goto?? cleanup;??
            ???
            ?if?? (!ReadProcessMemory(?? hProcess,??
            ??lpAddress,??
            ??wBuf,??
            ??dwSize,??
            ??&dwDummy??
            ??)??
            ??)??
            ??goto?? cleanup;??
            ???
            ?
            ?bRet?? =?? TRUE;??
            ???
            cleanup:??
            ???
            ?CloseHandle?? (hProcess);??
            ???
            ?
            ?return?? bRet;??
            }

            久久99国产综合精品免费| 狠狠久久亚洲欧美专区| 精品久久久久久无码中文字幕| 91久久精品国产91性色也| 久久99亚洲综合精品首页| 久久成人18免费网站| 久久久久亚洲AV无码专区首JN| 国内精品九九久久久精品| 久久se这里只有精品| 伊人久久综合精品无码AV专区| 麻豆一区二区99久久久久| 久久国产成人午夜aⅴ影院| 伊人色综合久久天天人手人婷| 91精品免费久久久久久久久| 久久AV高潮AV无码AV| 国产免费久久精品丫丫| 亚洲中文字幕无码久久综合网| 天天综合久久久网| 久久夜色精品国产噜噜噜亚洲AV | 国产精品久久久久久福利漫画 | A级毛片无码久久精品免费| 伊人久久精品影院| 99久久精品免费| 久久精品午夜一区二区福利| 狠狠久久综合伊人不卡| 777久久精品一区二区三区无码| 亚洲va中文字幕无码久久不卡| 久久人妻少妇嫩草AV蜜桃| 91精品国产色综合久久| 久久精品夜夜夜夜夜久久| 久久香综合精品久久伊人| 久久久黄色大片| 中文字幕久久亚洲一区| 中文字幕无码久久久| 一本色道久久综合| 久久乐国产综合亚洲精品| 久久天天躁狠狠躁夜夜2020| 国产日韩久久久精品影院首页| 国内精品久久久久久久涩爱| 国内精品伊人久久久久网站| 99久久免费国产精品|