COMO DESLIGAR UM COMPUTADOR RODANDO WINXP/WIN2K

USUARIO.EXCLUIDOS 21/12/2003 19:31:14
#1946
Eu quero fazer um programa q desliga o computador na hora marcada...
Até ai, tudo ok...
Esse programa já funciona no Win9X mas eu não consegui fazer ele desligar o meu computador q roda o WinXP, alguem sabe oq eu posso fazer pra ele desligar?
Por que no Win9X eu usei a API e deu certo, no XP essa mesma api deveria funcionar, não é?

quem quiser testar esse programa clica no link abaixo o programa tem 28kb
http://members.lycos.co.uk/bootpro/projeto/AutoOff.exe
USUARIO.EXCLUIDOS 22/12/2003 09:32:27
#1977
Resposta escolhida
Caro Geraldo:

Coloque os comandos abaixo em um modulo.

Funciona para NT, 2000 e XP

Use em seu programa:

ShutDownNT False ou
RebootNT False ou
LogoOFFNT False

para Shutdown/Reboot/Logoff controlados. Caso contrario

ShutDownNT True ou
RebootNT True ou
LogoOFFNT True

para as mesmas funções, só que neste caso ele Desliga, Reboota ou faz Logoff "no tranco" e é perigoso perder informações.

________________________________________________________________

Private Const EWX_LOGOFF = 0
Private Const EWX_SHUTDOWN = 1
Private Const EWX_REBOOT = 2
Private Const EWX_FORCE = 4
Private Const EWX_POWEROFF = &H8

Private Const TOKEN_ADJUST_PRIVILEGES = &H20
Private Const TOKEN_QUERY = &H8
Private Const SE_PRIVILEGE_ENABLED = &H2
Private Const ANYSIZE_ARRAY = 1
Private Const VER_PLATFORM_WIN32_NT = 2

Type OSVERSIONINFO
dwOSVersionInfoSize As Long
dwMajorVersion As Long
dwMinorVersion As Long
dwBuildNumber As Long
dwPlatformId As Long
szCSDVersion As String * 128
End Type

Type LUID
LowPart As Long
HighPart As Long
End Type

Type LUID_AND_ATTRIBUTES
pLuid As LUID
Attributes As Long
End Type

Type TOKEN_PRIVILEGES
PrivilegeCount As Long
Privileges(ANYSIZE_ARRAY) As LUID_AND_ATTRIBUTES
End Type

Private Declare Function GetCurrentProcess Lib "kernel32" () As Long
Private Declare Function OpenProcessToken Lib "advapi32" (ByVal ProcessHandle As Long, ByVal DesiredAccess As Long, TokenHandle As Long) As Long
Private Declare Function LookupPrivilegeValue Lib "advapi32" Alias "LookupPrivilegeValueA" (ByVal lpSystemName As String, ByVal lpName As String, lpLuid As LUID) As Long
Private Declare Function AdjustTokenPrivileges Lib "advapi32" (ByVal TokenHandle As Long, ByVal DisableAllPrivileges As Long, NewState As TOKEN_PRIVILEGES, ByVal BufferLength As Long, PreviousState As TOKEN_PRIVILEGES, ReturnLength As Long) As Long
Private Declare Function ExitWindowsEx Lib "user32" (ByVal uFlags As Long, ByVal dwReserved As Long) As Long
Private Declare Function GetVersionEx Lib "kernel32" Alias "GetVersionExA" (lpVersionInformation As OSVERSIONINFO) As Long 'Detect if the program is running under Windows NT

Public Function IsWinNT() As Boolean
Dim myOS As OSVERSIONINFO
myOS.dwOSVersionInfoSize = Len(myOS)
GetVersionEx myOS
IsWinNT = (myOS.dwPlatformId = VER_PLATFORM_WIN32_NT)
End Function

Private Sub EnableShutDown()
Dim hProc As Long
Dim hToken As Long
Dim mLUID As LUID
Dim mPriv As TOKEN_PRIVILEGES
Dim mNewPriv As TOKEN_PRIVILEGES
hProc = GetCurrentProcess()
OpenProcessToken hProc, TOKEN_ADJUST_PRIVILEGES + TOKEN_QUERY, hToken
LookupPrivilegeValue "", "SeShutdownPrivilege", mLUID
mPriv.PrivilegeCount = 1
mPriv.Privileges(0).Attributes = SE_PRIVILEGE_ENABLED
mPriv.Privileges(0).pLuid = mLUID
AdjustTokenPrivileges hToken, False, mPriv, 4 + (12 * mPriv.PrivilegeCount), mNewPriv, 4 + (12 * mNewPriv.PrivilegeCount)
End Sub

Public Sub ShutDownNT(Force As Boolean)
Dim ret As Long
Dim Flags As Long
Flags = EWX_POWEROFF
If Force Then Flags = Flags + EWX_FORCE
If IsWinNT Then EnableShutDown
ExitWindowsEx Flags, 0
End Sub

Public Sub RebootNT(Force As Boolean)
Dim ret As Long
Dim Flags As Long
Flags = EWX_REBOOT
If Force Then Flags = Flags + EWX_FORCE
If IsWinNT Then EnableShutDown
ExitWindowsEx Flags, 0
End Sub

Public Sub LogOffNT(Force As Boolean)
Dim ret As Long
Dim Flags As Long
Flags = EWX_LOGOFF
If Force Then Flags = Flags + EWX_FORCE
ExitWindowsEx Flags, 0
End Sub

----------------------------------------------------------------------------------------------

qq problema, mande-me um email

jbs@unimeds.com.br

Abraços

João Batista
USUARIO.EXCLUIDOS 22/12/2003 09:35:38
#1979
Em tempo:

Provavelmente a API que vc usou é a:

ExitWindows

que só funciona para Win98

A utlizada na mensagem acima é a:

ExitWindowsEx

João Batista


Tópico encerrado , respostas não são mais permitidas