• <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;??
            }

            色狠狠久久综合网| 久久国产综合精品五月天| 2021久久精品免费观看| 久久精品国产亚洲αv忘忧草| 看全色黄大色大片免费久久久| 亚洲国产精品无码久久青草| 2021国内精品久久久久久影院| 日韩人妻无码一区二区三区久久| 2021精品国产综合久久| 久久亚洲国产精品五月天婷| 久久精品无码一区二区无码 | 国产AⅤ精品一区二区三区久久| 99久久无码一区人妻| 一本一道久久综合狠狠老| 久久这里只有精品久久| 久久久精品国产免大香伊| 97精品伊人久久久大香线蕉| 99久久国产精品免费一区二区| 精品久久久久中文字| 久久久久人妻精品一区二区三区| 亚洲国产婷婷香蕉久久久久久| 99久久精品午夜一区二区| 亚洲精品美女久久777777| 欧美与黑人午夜性猛交久久久 | A级毛片无码久久精品免费| 久久亚洲精品成人无码网站| 国产69精品久久久久99尤物| 97r久久精品国产99国产精| 久久综合鬼色88久久精品综合自在自线噜噜 | 国内精品久久久久| 久久精品中文无码资源站| 性做久久久久久久久浪潮| 久久精品成人一区二区三区| 欧美久久综合性欧美| 97久久综合精品久久久综合| 久久精品国产亚洲av麻豆图片| 久久久国产视频| 久久九九兔免费精品6| 久久亚洲国产精品成人AV秋霞| 久久久这里只有精品加勒比| 中文精品99久久国产 |