1

需要一些帮助来调试这个问题。我尝试在线搜索和stackoverflow,但找不到解决方案。我对windows api相当陌生,所以请原谅我的无知。

基本上,我正在尝试运行一个 c++ 应用程序,该应用程序使用特定用户从 python 输出到 stdout 和 stderr。为此,我使用 LogonUser API 和 CreateProcessAsUser api 调用二进制文件,并使用 Pipes 来捕获输出和错误流。主要从 python win32 模块中的演示代码中获取代码。但是,由于某种原因,当我的进程转储到错误流时,它会挂在 WriteFile 上。查看故障转储我看到文件句柄是 2 (stderr)。有人可以帮我解决这个问题吗?

提前致谢

这是代码片段——

userToken = win32security.LogonUser(user, domain, password,
                                    win32con.LOGON32_LOGON_BATCH,
                                    win32con.LOGON32_PROVIDER_DEFAULT)

secAttrs = win32security.SECURITY_ATTRIBUTES()
secAttrs.bInheritHandle = 1
stdout_r, stdout_w = win32pipe.CreatePipe(secAttrs, 0)
stderr_r, stderr_w = win32pipe.CreatePipe(secAttrs, 0)

startupInfo = win32process.STARTUPINFO()
startupInfo.dwFlags = win32con.STARTF_USESTDHANDLES
startupInfo.hStdOutput = stdout_w
startupInfo.hStdError = stderr_w

ppid = win32api.GetCurrentProcess()
tmp = win32api.DuplicateHandle(ppid, stdout_r, ppid, 0, 0,
                               win32con.DUPLICATE_SAME_ACCESS)
win32file.CloseHandle(stdout_r)
stdout_r = tmp

procArgs = (None,       # appName
            cmd_line,   # commandLine
            None,       # processAttributes
            None,       # threadAttributes
            1,          # bInheritHandles
            win32process.CREATE_NEW_CONSOLE, # dwCreationFlags
            None,       # newEnvironment
            None,       # currentDirectory
            startupInfo)

procHandles = win32process.CreateProcessAsUser(userToken, *procArgs)

win32file.CloseHandle(stderr_w)
win32file.CloseHandle(stdout_w)
win32security.RevertToSelf()

# Wait for process to complete
hProcess, hThread, pid, tid = procHandles

stdout_buf = os.fdopen(msvcrt.open_osfhandle(stdout_r, 0), "rb")
stdout = stdout_buf.read()
stderr_buf = os.fdopen(msvcrt.open_osfhandle(stderr_r, 0), "rb")
stderr = stderr_buf.read()

win32event.WaitForSingleObject(hProcess, 3600*1000)
rc = win32process.GetExitCodeProcess(hProcess)
4

0 回答 0