Normalerweise wird bereits das Setup als Administrator gestartet und funktioniert dann einwandfrei...
Vielleicht funktioniert das hier:
Option Explicit
Private Const LOGON_WITH_PROFILE = &H1&
Private Const LOGON_NETCREDENTIALS_ONLY = &H2&
Private Const CREATE_DEFAULT_ERROR_MODE = &H4000000
Private Const CREATE_NEW_CONSOLE = &H10&
Private Const CREATE_NEW_PROCESS_GROUP = &H200&
Private Const CREATE_SEPARATE_WOW_VDM = &H800&
Private Const CREATE_SUSPENDED = &H4&
Private Const CREATE_UNICODE_ENVIRONMENT = &H400&
Private Const ABOVE_NORMAL_PRIORITY_CLASS = &H8000&
Private Const BELOW_NORMAL_PRIORITY_CLASS = &H4000&
Private Const HIGH_PRIORITY_CLASS = &H80&
Private Const IDLE_PRIORITY_CLASS = &H40&
Private Const NORMAL_PRIORITY_CLASS = &H20&
Private Const REALTIME_PRIORITY_CLASS = &H100&
Private Type PROCESS_INFORMATION
hProcess As Long
hThread As Long
dwProcessId As Long
dwThreadId As Long
End Type
Private Type STARTUPINFO
cb As Long
lpReserved As Long
lpDesktop As Long
lpTitle As Long
dwX As Long
dwY As Long
dwXSize As Long
dwYSize As Long
dwXCountChars As Long
dwYCountChars As Long
dwFillAttribute As Long
dwFlags As Long
wShowWindow As Integer
cbReserved2 As Integer
lpReserved2 As Byte
hStdInput As Long
hStdOutput As Long
hStdError As Long
End Type
Private Declare Function CreateProcessWithLogon Lib "Advapi32" Alias _
"CreateProcessWithLogonW" (ByVal lpUsername As Long, ByVal lpDomain As Long, _
ByVal lpPassword As Long, ByVal dwLogonFlags As Long, ByVal lpApplicationName _
As Long, ByVal lpCommandLine As Long, ByVal dwCreationFlags As Long, ByVal _
lpEnvironment As Long, ByVal lpCurrentDirectory As Long, lpStartupInfo As _
STARTUPINFO, lpProcessInfo As PROCESS_INFORMATION) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As _
Long
Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
Private Sub Command1_Click()
Dim lpUsername As String
Dim lpDomain As String
Dim lpPassword As String
Dim lpApplicationName As String
Dim lpCommandLine As String
Dim lpCurrentDirectory As String
Dim StartInfo As STARTUPINFO
Dim ProcessInfo As PROCESS_INFORMATION
On Error GoTo Abbruch
lpCommandLine = vbNullString
lpCurrentDirectory = vbNullString
StartInfo.cb = LenB(StartInfo)
StartInfo.dwFlags = 0&
lpUsername = "Administrator" 'Benutzer mit administrativem Account
lpDomain = Environ("Computername") 'Oder eben direkt der Domänenname
lpPassword = "hierstehtdaspassworddesadministrators" 'Das Passwort...
CreateProcessWithLogon StrPtr(lpUsername), StrPtr(lpDomain), StrPtr( _
lpPassword), LOGON_WITH_PROFILE, StrPtr(Shell(Environ("COMSPEC") & " /C" & _
"regedit", vbHide)), StrPtr(lpCommandLine), _
CREATE_DEFAULT_ERROR_MODE Or CREATE_NEW_CONSOLE Or CREATE_NEW_PROCESS_GROUP, _
ByVal 0&, StrPtr(lpCurrentDirectory), StartInfo, ProcessInfo
CloseHandle ProcessInfo.hThread
CloseHandle ProcessInfo.hProcess
Exit Sub
Abbruch:
MsgBox "Es ist der Fehler " & Err.Number & ", " & Err.Description & "" & _
"aufgetreten!"
End Sub EALA FREYA FRESENA |