!!!求救:一段98/2k下定时关机的代码报错,解决给200分!
djfdd 2004-03-24 10:46:24 /////一段定时关机的代码,但我编译运行后出现运行错误,fORM第4行'变量未定义',请教??
'---FORM中-----------------------
Option Explicit
Dim uFlags As Long
Private Sub Form_Load()
Timer1.Enabled = False
Timer1.Interval = 1000
Timer1.Enabled = True
End Sub
Private Sub Timer1_Timer()
If Time > CDate("0:00:00") And Time < CDate("8:00:00") Then
AdjustTokenPrivilegesForNT
ExitWindowsEx uFlags, 4
ExitWindowsEx EWX_FORCE, 4
End If
End Sub
'------BAS中----------------
Option Explicit
Declare Function ExitWindowsEx Lib "user32" (ByVal uFlags As Long, ByVal dwReserved As Long) As Long
'ExitWindowsExµÄ²ÎÊýuflags£¬ÓÐËĸö¶ÔÓ¦Öµ£¬·Ö±ðÊÇ£º
Public Const EWX_LOGOFF = 0 'Í˳ö(×¢Ïú)
Public Const EWX_SHUTDOWN = 1 '¹Ø»ú
Public Const EWX_REBOOT = 2 'ÖØÆô¶¯
Public Const EWX_FORCE = 4 'Ç¿Öƹػú£¬¼´²»Í¨ÖªÏÖÔڻӦÓóÌÐòÈÃÆäÏÈ×ÔÎҹرÕ
Public Const TOKEN_ADJUST_PRIVILEGES = &H20
Public Const TOKEN_QUERY = &H8
Public Const SE_PRIVILEGE_ENABLED = &H2
Public Const ANYSIZE_ARRAY = 1
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
Declare Function GetCurrentProcess Lib "kernel32" () As Long
Declare Function LookupPrivilegeValue Lib "advapi32.dll" Alias "LookupPrivilegeValueA" (ByVal lpSystemName As String, ByVal lpName As String, lpLuid As LUID) As Long
Declare Function AdjustTokenPrivileges Lib "advapi32.dll" (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
Declare Function OpenProcessToken Lib "advapi32.dll" (ByVal ProcessHandle As Long, ByVal DesiredAccess As Long, TokenHandle As Long) As Long
'Õâ¸öº¯Êý¾ÍÊÇÓÃÓÚNT¹Ø»úÖÐʹÓõÄ
Sub AdjustTokenPrivilegesForNT()
Dim hdlProcessHandle As Long
Dim hdlTokenHandle As Long
Dim tmpLuid As LUID
Dim tkp As TOKEN_PRIVILEGES
Dim tkpNewButIgnored As TOKEN_PRIVILEGES
Dim lBufferNeeded As Long
hdlProcessHandle = GetCurrentProcess()
OpenProcessToken hdlProcessHandle, (TOKEN_ADJUST_PRIVILEGES Or _
TOKEN_QUERY), hdlTokenHandle
LookupPrivilegeValue "", "SeShutdownPrivilege", tmpLuid
tkp.PrivilegeCount = 1
tkp.Privileges(0).pLuid = tmpLuid
tkp.Privileges(0).Attributes = SE_PRIVILEGE_ENABLED
AdjustTokenPrivileges hdlTokenHandle, False, tkp, _
Len(tkpNewButIgnored), tkpNewButIgnored, _
lBufferNeeded
End Sub