Главная страница
    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.061 c
14-1094744277
X9
2004-09-09 19:37
2004.09.26
Справка по Opera


3-1093634976
VflowerW
2004-08-27 23:29
2004.09.26
Помогите пожалуйста разобраться с TreeView


1-1094711126
EthernalWonderer
2004-09-09 10:25
2004.09.26
Перехват клавиши мыши, когда курсор над любым элементом окна


8-1088781061
Epifun
2004-07-02 19:11
2004.09.26
Громкость в Windows


1-1094588788
Антон
2004-09-08 00:26
2004.09.26
Подскажите как сделать тест с возможностью нескольких ответов.





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