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

Вниз

Определение версии операционной системы и привилегий пользователя   Найти похожие ветки 

 
Smok_er   (2002-08-12 23:51) [0]

Уважаемые мастера!
Подскажите пожалуйста ответ! Кучу доков перелопатил - нигде не могу найти.


 
Poirot ©   (2002-08-13 04:47) [1]

Версию ос мона посмотреть ПЕРЕМЕННЫЙЕ в SysUtils или юзая GetVersionEx


 
Внук ©   (2002-08-13 07:52) [2]

Начиная с Win2000 появилась также VerifyVersionInfo


 
Smok_er   (2002-08-13 23:11) [3]

Спасибо! А привилегии пользователя? Именно это для меня более важно!


 
Макс Черных ©   (2002-08-13 23:43) [4]

Вот для примера функция, определяющая является ли
текущий пользователь администратором.
Используя разные DOMAIN_ALIAS_RID... при вызове
AllocateAndInitializeSid можно определять и другие
типы пользователей.

function IsAdmin: Boolean;
const
SECURITY_NT_AUTHORITY: SID_IDENTIFIER_AUTHORITY =
(Value: (0,0,0,0,0,5)); // ntifs

SECURITY_BUILTIN_DOMAIN_RID: DWORD = $00000020;
DOMAIN_ALIAS_RID_ADMINS: DWORD = $00000220;
DOMAIN_ALIAS_RID_USERS : DWORD = $00000221;
DOMAIN_ALIAS_RID_GUESTS: DWORD = $00000222;
DOMAIN_ALIAS_RID_POWER_: DWORD = $00000223;

var
hAccessToken: THandle;
ptgGroups: PTokenGroups;
dwInfoBufferSize: DWORD;
psidAdministrators: PSID;
x: Integer;
bSuccess: BOOL;
begin
Result := False;
bSuccess := OpenThreadToken(GetCurrentThread, TOKEN_QUERY, True, hAccessToken);
if not bSuccess then
begin
if GetLastError = ERROR_NO_TOKEN then
bSuccess := OpenProcessToken(GetCurrentProcess, TOKEN_QUERY,
hAccessToken);
end;
if bSuccess then
begin
GetMem(ptgGroups, 1024);
bSuccess := GetTokenInformation(hAccessToken, TokenGroups,
ptgGroups, 1024, dwInfoBufferSize);
CloseHandle(hAccessToken);
if bSuccess then
begin
AllocateAndInitializeSid(SECURITY_NT_AUTHORITY, 2,
SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS,
0, 0, 0, 0, 0, 0, psidAdministrators);
{$R-}
for x := 0 to ptgGroups.GroupCount - 1 do
if EqualSid(psidAdministrators, ptgGroups.Groups[x].Sid) then
begin
Result := True;
Break;
end;
{$R+}
FreeSid(psidAdministrators);
end;
FreeMem(ptgGroups);
end;
end;


 
Smok_er   (2002-08-14 00:00) [5]

Большое спасибо! Прошу извинить за небольшой оффтопик... Сабж нужен для определения, есть ли у пользователя права писать в ветку LOCAL_MACHINE... Так вот, может кто знает, как определить, может ли юзер писАть в эту ветку или нет. Вроде как не только админы могут это делать, но и к примеру power users вроде...


 
Внук ©   (2002-08-14 08:51) [6]

Открой ключ реестра с правом KEY_WRITE под текущим пользователем, и сразу узнаешь :)


 
Bass ©   (2002-08-14 11:47) [7]

Заходишь в Windows.pas ищешь GetSecurityDescriptorGroup тискаешь F1 а потом Group и титааааааааешь!


 
Anatoly Podgoretsky ©   (2002-08-14 11:53) [8]

Зачем в обход, см. Внук © (14.08.02 08:51) и сразу ответ можно или нет


 
Smok_er   (2002-08-14 22:44) [9]

У меня на момент написания этих строк уже появилась идея пробной записи в LOCAL_MACHINE и обрабатывая исключение определить права пользователя. Спасибо всем!



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

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

Наверх




Память: 0.48 MB
Время: 0.018 c
1-68758
koly01
2002-10-11 12:28
2002.10.21
CopyFile не работатет очень нужно помочь


1-68842
User_OKA
2002-10-10 07:25
2002.10.21
Остановка цикла


3-68609
cherepovets
2002-09-28 16:06
2002.10.21
Calc поле


1-68759
Sego
2002-10-11 14:16
2002.10.21
Как использовать dll (как подключить к Delphi приложению)


7-69027
Hellman
2002-08-02 19:15
2002.10.21
Прочти :)