Ok, nach einer vollständigen und peniblen Neuinstallation funktioniert Jwa und
Jwscl jetzt wohl. Scheint was durcheinander gekommen zu sein mit der alten und der aktuellen Version. Nun gut, das geht ja jetzt schon mal. Dann versuche ich jetzt mal da drauf aufzubauen.
Das habe ich jetzt zusammengebasteln:
Delphi-Quellcode:
var
UserToken: TJwSecurityToken;
ConsoleUser : TJwSecurityId;
StartupInfo: TStartupInfo;
ProcessInfo: TProcessInformation;
UserEnvironment : LPVOID;
begin
UserToken := TJwSecurityToken.CreateWTSQueryUserTokenEx(nil, WtsGetActiveConsoleSessionID);
try
ZeroMemory(@StartupInfo, SizeOf(StartupInfo));
StartupInfo.cb := SizeOf(StartupInfo);
StartupInfo.lpDesktop := nil;
StartupInfo.dwFlags := STARTF_USESHOWWINDOW or STARTF_FORCEONFEEDBACK;
StartupInfo.wShowWindow := SW_SHOW;
CreateEnvironmentBlock(UserEnvironment, UserToken.TokenHandle, True); //<- so richtig?
CreateProcess(nil,
PChar('c:\test.exe'),
nil,
nil,
False,
NORMAL_PRIORITY_CLASS or CREATE_NEW_PROCESS_GROUP,
UserEnvironment, //<- EnvironmentBlock
nil,
StartupInfo,
ProcessInfo);
finally
FreeAndNil(UserToken);
end;
end;
1. Ich verwende CreateProcess und nicht CreateProcessAsUser, weil ich ja gar nicht brauche, dass das Programm als anderer Benutzer ausgeführt wird. Ist das dann so OK?
2. Die Umgebung (UserEnvironment) wird nicht richtig verarbeitet. Wenn ich nil statt UserEnvironment übergebe, dann startet das Programm als SYSTEM hat aber auch dessen Umgebungsvariablen. Wenn ich aber versuche, den EnvironmentBlock zu erstellen (wie im Code dargestellt), dann startet das Programm gar nicht mehr. Wo liegt der Fehler? Bzw. wie geht das richtig?
3.
Selbst wenn das dann starten würde, bin ich immer noch der Meinung, dass bei Verwendung von WtsGetActiveConsoleSessionID ich die Umgebung von SYSTEM erhalte und nicht vom User. Wie dann? edit: Hm, habe das jetzt mit UserToken.GetTokenUserName überprüft und es ist der Benutzername. Sollte dann also wohl doch so funktionieren...