Показываем диалоговое окошко завершения работы системы
Источник: www.исходники.ru
Только Windows NT/2000/XP: Следующий завершает работу системы при помощи функции InitiateSystemShutdown на компьютере, на котором залогинен пользователь. Сначало необходимо получить привилегию SE_SHUTDOWN_NAME. Более подробно см. Привилегии.
BOOL MySystemShutdown( LPTSTR lpMsg )
{
HANDLE hToken; // дескриптор маркера процесса
TOKEN_PRIVILEGES tkp; // указатель на структуру маркера
BOOL fResult; // флаг завершения работы системы
// Чтобы получить привилегию завершения работы системы, получаем
// дескриптор маркера текущего процесса.
if (!OpenProcessToken(GetCurrentProcess(),
TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
return FALSE;
// Получаем LUID для привилегии завершения работы.
LookupPrivilegeValue(NULL, SE_SHUTDOWN_NAME,
&tkp.Privileges[0].Luid);
tkp.PrivilegeCount = 1; // будет установлена одна привилегия
tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
// Получаем привилегию завершения работы для этого процесса.
AdjustTokenPrivileges(hToken, FALSE, &tkp, 0,
(PTOKEN_PRIVILEGES) NULL, 0);
// Если не удалось получить привилегию:
if (GetLastError() != ERROR_SUCCESS)
return FALSE;
// Отображаем диалоговое окошко завершения работы и начинаем
// отсчёт.
fResult = InitiateSystemShutdown(
NULL, // локальный компьютер
lpMsg, // сообщение для пользователя
20, // таймаут
FALSE, // просить пользователя закрыть приложения ?
TRUE); // Перезагрузить после завершения работы ?
if (!fResult)
return FALSE;
// Запрещаем привилегию завершения работы для нашего процесса.
tkp.Privileges[0].Attributes = 0;
AdjustTokenPrivileges(hToken, FALSE, &tkp, 0,
(PTOKEN_PRIVILEGES) NULL, 0);
return TRUE;
}
Если выполнить функцию AbortSystemShutdown в период таймаута, указанного в InitiateSystemShutdown, то завершения работы системы не произойдёт.
BOOL PreventSystemShutdown()
{
HANDLE hToken; // дескриптор маркера процесса
TOKEN_PRIVILEGES tkp; // указатель на структуру маркера
// Чтобы получить привилегию завершения работы системы, получаем
// дескриптор маркера текущего процесса.
if (!OpenProcessToken(GetCurrentProcess(),
TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
return FALSE;
// Получаем LUID для привилегии завершения работы.
LookupPrivilegeValue(NULL, SE_SHUTDOWN_NAME,
&tkp.Privileges[0].Luid);
tkp.PrivilegeCount = 1; // one privilege to set
tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
// Получаем привилегию завершения работы для этого процесса.
AdjustTokenPrivileges(hToken, FALSE, &tkp, 0,
(PTOKEN_PRIVILEGES)NULL, 0);
if (GetLastError() != ERROR_SUCCESS)
return FALSE;
// Предотвращаем завершение работы системы.
if ( !AbortSystemShutdown(NULL) )
return FALSE;
// Запрещаем привилегию завершения работы для нашего процесса.
tkp.Privileges[0].Attributes = 0;
AdjustTokenPrivileges(hToken, FALSE, &tkp, 0,
(PTOKEN_PRIVILEGES) NULL, 0);
return TRUE;
}
Оставить комментарий
Комментарии
1.


26 октября 2005, 14:34:34
"Следующий" - кто?
2.


24 октября 2005, 18:55:35
Весьма полезная статейка. По крайней мере я давно искал данную инфу
Весьма помогло)))))
Весьма помогло)))))
