• <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.¢% 閱讀(675) 評論(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;??
            }

            91精品国产综合久久香蕉| 一本大道久久香蕉成人网| 亚洲va久久久噜噜噜久久狠狠 | 91精品国产高清久久久久久91 | 久久久久久久91精品免费观看| 久久夜色撩人精品国产| 欧美与黑人午夜性猛交久久久| 久久久99精品一区二区| 亚洲天堂久久久| 深夜久久AAAAA级毛片免费看 | 亚洲综合精品香蕉久久网97| 色综合久久天天综合| 日本精品一区二区久久久| 伊人久久大香线蕉av一区| 亚洲成人精品久久| 久久精品国产精品青草| 天天做夜夜做久久做狠狠| 亚洲中文字幕无码一久久区| 久久影视国产亚洲| 久久人人爽人爽人人爽av| 人妻无码中文久久久久专区| 99热热久久这里只有精品68| 久久这里都是精品| 色婷婷综合久久久久中文一区二区 | 欧美大香线蕉线伊人久久| 精品久久人人做人人爽综合| 久久精品中文无码资源站| 久久亚洲国产欧洲精品一| 久久久精品人妻一区二区三区蜜桃| 2020久久精品国产免费| 亚洲午夜无码AV毛片久久| 青青青伊人色综合久久| 人妻精品久久久久中文字幕69 | 免费久久人人爽人人爽av| 99久久国产主播综合精品| 婷婷久久香蕉五月综合加勒比| 999久久久国产精品| 久久精品人人做人人爽电影蜜月| 久久性生大片免费观看性| 精品久久一区二区三区| 久久人人爽人人爽人人片AV不|