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

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

            [Reference]獲取其它進(jìn)程命令行

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

            久久免费大片| 久久精品人人做人人爽97| 久久精品国产精品亚洲| 日韩欧美亚洲综合久久影院Ds| 亚洲精品白浆高清久久久久久 | 伊人热热久久原色播放www| 香蕉久久av一区二区三区| 国产999精品久久久久久| 久久天天躁夜夜躁狠狠| 青青草原综合久久| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 丁香五月综合久久激情| 亚洲精品国产字幕久久不卡 | 欧美一区二区三区久久综合| 国产精品久久久久一区二区三区 | 狠狠色综合久久久久尤物| 人妻精品久久久久中文字幕69| 看全色黄大色大片免费久久久| 日韩人妻无码精品久久久不卡| 亚洲精品国产综合久久一线| 国产成人久久久精品二区三区| 久久久久99精品成人片直播| 麻豆精品久久久久久久99蜜桃| 久久亚洲精品无码播放| 婷婷综合久久狠狠色99h| 久久久噜噜噜www成人网| 久久精品国产乱子伦| 一本大道久久香蕉成人网| 久久www免费人成看国产片| 亚洲国产天堂久久综合网站| 精品久久久久久无码专区不卡| 一本久久a久久精品vr综合| 少妇无套内谢久久久久| 人妻无码久久精品| 久久久久99精品成人片三人毛片 | 久久精品国产欧美日韩99热| 亚洲国产成人精品女人久久久| 国产激情久久久久影院老熟女| 亚洲午夜久久影院| 久久精品无码一区二区app| 久久成人精品|