Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "WinAPI";
Текущий архив: 2004.09.26;
Скачать: [xml.tar.bz2];

Вниз

ParamStr(X)   Найти похожие ветки 

 
Sur   (2004-08-12 14:08) [0]

У меня есть xэндл процесса(приложения). Как по нему мне узнать
параметры с котороми он был запущен(То есть ParamStr(1)... ParamStr(ParamCount)???


 
Digitman ©   (2004-08-12 14:24) [1]

внедряешь в этот процесс свою нить

в коде нити читаешь структуру PEB

в поле PEB.ProcessParameters лежит адрес структуры RTL_USER_PROCESS_PARAMETERS

в поле структуры RTL_USER_PROCESS_PARAMETERS.CommandLine  лежит то что тебе нужно


 
Sur   (2004-08-12 14:31) [2]

я не совсем понял, можно чуть попадробнее или может маленький
примерчик,.
спасибо за ответ.


 
Digitman ©   (2004-08-12 14:34) [3]


> я не совсем понял


что конкретно ?


> можно чуть попа


насчет попы - это не ко мне)


 
Digitman ©   (2004-08-12 14:38) [4]

TUNICODE_STRING = packed record
   Length: Word;
   MaximumLength: Word;
   Buffer: PWideChar;
 end;
 TNtUnicodeString = TUNICODE_STRING;
 PNtUnicodeString = ^TNtUnicodeString;

TRTL_USER_PROCESS_PARAMETERS = packed record
 MaximumLength    : Cardinal;
 Length           : Cardinal;
 Flags            : Cardinal;
 DebugFlags       : Cardinal;
 ConsoleHandle    : THandle;
 ConsoleFlags     : Cardinal;
 StandardInput    : Pointer;
 StandardOutput   : Pointer;
 StandardError    : Pointer;
 CurrentDirectory : TCURDIR;
 DllPath          : TUNICODE_STRING;
 ImagePathName    : TUNICODE_STRING;
 CommandLine      : TUNICODE_STRING;  
 Environment      : Pointer;
 StartingX        : Cardinal;
 StartingY        : Cardinal;
 CountX           : Cardinal;
 CountY           : Cardinal;
 CountCharsX      : Cardinal;
 CountCharsY      : Cardinal;
 FillAttribute    : Cardinal;
 WindowFlags      : Cardinal;
 ShowWindowFlags  : Cardinal;
 WindowTitle      : TUNICODE_STRING;
 DesktopInfo      : TUNICODE_STRING;
 ShellInfo        : TUNICODE_STRING;
 RuntimeData      : TUNICODE_STRING;
//   +0x090 CurrentDirectores : [32] _RTL_DRIVE_LETTER_CURDIR
end;

TPEB = packed record
{000}   InheritedAddressSpace : ByteBool;
{001}   ReadImageFileExecOptions : ByteBool;
{002}   BeingDebugged    : ByteBool;
{003}   SpareBool        : ByteBool;
{004}   Mutant           : Pointer;
{008}   ImageBaseAddress : Pointer;
{00C}   LdrData          : PPEB_LDR_DATA; { Modules list }
{010}   ProcessParameters : PRTL_USER_PROCESS_PARAMETERS; { _RTL_USER_PROCESS_PARAMETERS }
{014}   SubSystemData    : Pointer;
{018}   ProcessHeap      : Pointer;
{01C}   FastPebLock      : PRTLCriticalSection;
{020}   FastPebLockRoutine : Pointer;
{024}   FastPebUnlockRoutine : Pointer;
{028}   EnvironmentUpdateCount : Cardinal;
{02C}   KernelCallbackTable : Pointer;
{030}   SystemReserved   : Cardinal;
{034}   ExecuteOptions   : Cardinal; {Pos 0, 2 Bits, SpareBits  : Pos 2, 30 Bits }
{038}   FreeList         : Pointer; { _PEB_FREE_BLOCK }
{03C}   TlsExpansionCounter : Cardinal;
{040}   TlsBitmap        : Pointer;
{044}   TlsBitmapBits    : array[0..1] of Cardinal;
{04C}   ReadOnlySharedMemoryBase : Pointer;
{050}   ReadOnlySharedMemoryHeap : Pointer;
{054}   ReadOnlyStaticServerData : Pointer;
{058}   AnsiCodePageData : Pointer;
{05C}   OemCodePageData  : Pointer;
{060}   UnicodeCaseTableData : Pointer;
{064}   NumberOfProcessors : Cardinal;
{068}   NtGlobalFlag     : Cardinal;
{06C}   Reserved0        : DWord;
{070}   CriticalSectionTimeout : TLARGEINTEGER;
{078}   HeapSegmentReserve : Cardinal;
{07C}   HeapSegmentCommit : Cardinal;
{080}   HeapDeCommitTotalFreeThreshold : Cardinal;
{084}   HeapDeCommitFreeBlockThreshold : Cardinal;
{088}   NumberOfHeaps    : Cardinal;
{08C}   MaximumNumberOfHeaps : Cardinal;
{090}   ProcessHeaps     : Pointer;
{094}   GdiSharedHandleTable : Pointer;
{098}   ProcessStarterHelper : Pointer;
{09C}   GdiDCAttributeList : Cardinal;
{0A0}   LoaderLock       : PRTLCriticalSection;
{0A4}   OSMajorVersion   : Cardinal;
{0A8}   OSMinorVersion   : Cardinal;
{0AC}   OSBuildNumber    : Word;
{0AE}   OSCSDVersion     : Word;
{0B0}   OSPlatformId     : Cardinal;
{0B4}   ImageSubsystem   : Cardinal;
{0B8}   ImageSubsystemMajorVersion : Cardinal;
{0BC}   ImageSubsystemMinorVersion : Cardinal;
{0C0}   ImageProcessAffinityMask : Cardinal;
{0C4}   Reserved2        : array[0..34] of DWord;
{150}   Reserved3        : DWord;
{154}   Reserved4        : array[0..31] of DWord;
{1D4}   Win32WindowStation : THandle;
{1D8}   Reserved5        : DWord;
{1DC}   Reserved6        : DWord;
{1E0}   CSDVersion       : PWord;
{1E4}   Reserved7        : DWord;
{1E8}
 end;

PPEB = ^TPEB;


 
Digitman ©   (2004-08-12 14:39) [5]

указатель на структуру TPeb м.б. получен так

function GetCurrentPEB: PPEB;
asm
 mov   eax, fs:[TTeb.Peb]
end;


 
Sur   (2004-08-12 14:40) [6]

что значит внедрять в процесс свою нить?


 
Игорь Шевченко ©   (2004-08-12 14:40) [7]

Digitman ©   (12.08.04 14:39)

Можно и без внедрения, через ReadProcessMemory :)


 
Sur   (2004-08-12 14:42) [8]

ладно счас попробую.
Спасибо за ответы


 
Digitman ©   (2004-08-12 14:46) [9]


> Игорь Шевченко ©   (12.08.04 14:40) [7]


не задавался целью выяснить, можно ли так ..

а fs-то куда кажет ?


 
Игорь Шевченко ©   (2004-08-12 14:50) [10]

Digitman ©   (12.08.04 14:46) [9]


> не задавался целью выяснить, можно ли так ..


http://www.schevchenko.net.ru/SRC/EnumFunctions_60.zip - так тут как раз пример.


> а fs-то куда кажет ?


А он всегда по одному адресу - $7FFDF000


 
Digitman ©   (2004-08-12 14:54) [11]


> Игорь Шевченко ©   (12.08.04 14:50) [10]


за Винтукей - да ... а в прочих НТbased-системах ? здесь утверждать не могу


 
Игорь Шевченко ©   (2004-08-12 15:07) [12]

Digitman ©   (12.08.04 14:54) [11]


> а в прочих НТbased-системах ? здесь утверждать не могу


Начиная, по крайней мере, с NT4. Это документировано, насколько я помню.



Страницы: 1 вся ветка

Форум: "WinAPI";
Текущий архив: 2004.09.26;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.48 MB
Время: 0.037 c
1-1094827882
redlord
2004-09-10 18:51
2004.09.26
пауза


1-1095155759
Kovsh
2004-09-14 13:55
2004.09.26
Как изменить цвет выделения в StringGrids


1-1094571759
Klopan
2004-09-07 19:42
2004.09.26
CopyFile


1-1094708202
Layner
2004-09-09 09:36
2004.09.26
Как узнать, что PopupMenu закрылся?


6-1089828767
Фёдор Мегатронов
2004-07-14 22:12
2004.09.26
Как послать php запросы ?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский