Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.09.26;
Скачать: CL | DM;

Вниз

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 вся ветка

Текущий архив: 2004.09.26;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.032 c
3-1093835888
Sirus
2004-08-30 07:18
2004.09.26
Насчет индексов Interbase...


1-1094994303
Gear
2004-09-12 17:05
2004.09.26
Как в ListBox красиво обрезать строки по ширине ListBox, и ...


1-1095069384
Mishel
2004-09-13 13:56
2004.09.26
Clipboard: ограничения по размеру


4-1092910057
JJJ
2004-08-19 14:07
2004.09.26
WinAPI: Изменение шрифта и стиля Edita


3-1093454029
MaxN
2004-08-25 21:13
2004.09.26
JPEG





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский