为了账号安全,请及时绑定邮箱和手机立即绑定

CreateProcessAsUser 到 ImpersonateLoggedOnUser

CreateProcessAsUser 到 ImpersonateLoggedOnUser

C#
慕的地8271018 2023-08-20 10:01:32
来自(哪里Windows C# 有没有办法使用父进程的 Kerberos 票证创建新进程?支持使用 SSPI 进行多进程的 kerberos 约束委派我正在尝试将 Kerberos 凭据从一个进程复制到另一个进程以调用远程命令。史蒂夫非常有帮助,但我对如何创建子进程,使用正确的凭据句柄加载它和模拟,然后获取同一个子进程来执行调用后的实际命令有点困惑DuplicateHandles 要求子进程首先存在。我的问题是,如何让子进程执行我最初打算让它作为 CreateProcessAsUser 模拟执行的命令?到目前为止的代码:var CurrentIdentity = ((WindowsIdentity)User.Identity).Token;IntPtr parentHandle = IntPtr.Zero;CloneParentProcessToken.QuerySecurityContextToken(ref CurrentIdentity, out parentHandle);IntPtr parentProcessHandle = Process.GetCurrentProcess().Handle;currentUser = System.Security.Principal.WindowsIdentity.GetCurrent().Name;//Create Child Process as UserIntPtr childProcessHandle = CreateProcessAsUser();IntPtr lpTargetHandle = IntPtr.Zero;//Duplicate parent security handle into childif (CloneParentProcessToken.DuplicateHandle(parentProcessHandle, parentHandle, childProcessHandle, out lpTargetHandle,    ProcessUtility.TOKEN_IMPERSONATE, true, (uint)0x00000002)){    int childHandleProcessID = CloneParentProcessToken.GetProcessId(lpTargetHandle);    IntPtr newChildProcess = ProcessUtility.OpenProcess(ProcessUtility.ProcessAccessFlags.All, true, childHandleProcessID);    IntPtr newProcessAccessTokenHandle = IntPtr.Zero;    if (ProcessUtility.OpenProcessToken(newChildProcess, ProcessUtility.TOKEN_IMPERSONATE, out newProcessAccessTokenHandle))    {        //Impersonate the user in the new child process        if (CloneParentProcessToken.ImpersonateLoggedOnUser(newProcessAccessTokenHandle))        {            //newChildProcess is pointer to child process with token and impersonation            Process child = Process.GetProcessById(childHandleProcessID);            //Have child process execute???        }    }
查看完整描述

1 回答

?
慕尼黑的夜晚无繁华

TA贡献1864条经验 获得超6个赞

因为对 DuplicateHandles 的调用要求子进程首先存在。

您可以设置hTargetProcessHandle为当前进程,并bInheritHandle设置为true,以便目标进程创建的新进程可以继承重复的句柄。然后通过IPC将新的token传递给子进程。


查看完整回答
反对 回复 2023-08-20
  • 1 回答
  • 0 关注
  • 107 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信