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

Вниз

Как получить права отладчика?   Найти похожие ветки 

 
GrayFace ©   (2005-05-10 16:01) [0]

Как получить права на применение OpenProcess к системным процессам (типа WinLogon)?


 
VMcL ©   (2005-05-10 16:10) [1]

Как-то так, если не ошибаюсь:

function EnableTokenPrivilege(const ATokenHandle: THandle; const APrivilege: String;
 const AEnable: Boolean): DWORD;

 function InternalEnableTokenPrivilege: DWORD;
 var
   Luid: TLargeInteger;
   Priv: TTokenPrivileges;
 begin
   if not LookupPrivilegeValue(nil, PChar(APrivilege), Luid) then
   begin
     Result := GetLastError;
     Exit;
   end;

   FillChar(Priv, SizeOf(Priv), 0);
   Priv.PrivilegeCount := 1;
   if AEnable then
     Priv.Privileges[0].Attributes := SE_PRIVILEGE_ENABLED;
   Priv.Privileges[0].Luid := Luid;

   if not AdjustTokenPrivileges(ATokenHandle, False, Priv, 0, TTokenPrivileges(nil^),
     DWORD(nil^)) then
   begin
     Result := GetLastError;
     Exit;
   end;

   Result := ERROR_SUCCESS;
 end;

begin
 Result := InternalEnableTokenPrivilege;
 SetLastError(Result);
end;

function EnableTokenDebugPrivilege(const ATokenHandle: THandle; const AEnable: Boolean): DWORD;
const
 DebugPrivilege = "SeDebugPrivilege";
begin
 Result := EnableTokenPrivilege(ATokenHandle, DebugPrivilege, AEnable);
end;

function EnableProcessDebugPrivilege(const AProcessId: DWORD; const AEnable: Boolean): DWORD;
const
 ProcessDesiredAccess = PROCESS_QUERY_INFORMATION;
 TokenDesiredAccess = TOKEN_ADJUST_PRIVILEGES;
var
 ProcessHandle, TokenHandle: THandle;
begin
 ProcessHandle := OpenProcess(ProcessDesiredAccess, False, AProcessId);
 if ProcessHandle = 0 then
 begin
   Result := GetLastError;
   Exit;
 end;
 try
   if not OpenProcessToken(ProcessHandle, TokenDesiredAccess, TokenHandle) then
   begin
     Result := GetLastError;
     Exit;
   end;
   try
     Result := EnableTokenDebugPrivilege(TokenHandle, AEnable);
   finally
     CloseHandle(TokenHandle);
   end;
 finally
   CloseHandle(ProcessHandle);
 end;
end;


 
VMcL ©   (2005-05-10 16:11) [2]

P.S. Юзать например так:

EnableProcessDebugPrivilege(GetCurrentProcessId);


 
VMcL ©   (2005-05-10 16:11) [3]

>>VMcL ©   (10.05.05 16:11) [2]

Сорри, вот так:
EnableProcessDebugPrivilege(GetCurrentProcessId, True);


 
GrayFace ©   (2005-05-12 20:01) [4]

Спасибо. Попробую.



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

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

Наверх




Память: 0.47 MB
Время: 0.038 c
14-1118524157
u-12
2005-06-12 01:09
2005.07.11
Помогите разобраться с датакабелем Самсунга


3-1117033219
Peter_cc
2005-05-25 19:00
2005.07.11
Невидемые записи


11-1084224094
Диман
2004-05-11 01:21
2005.07.11
TabControl и ширина кнопок


10-1095145890
Суслик
2004-09-14 11:11
2005.07.11
structured storage


4-1115996081
_Вован
2005-05-13 18:54
2005.07.11
Сообщение "Ошибка 1931..." при инсталляции моей проги :(