gpt4 book ai didi

windows - 如何找到用户刚刚启动的可执行文件?

转载 作者:可可西里 更新时间:2023-11-01 11:40:33 28 4
gpt4 key购买 nike

我正在开发一个测试框架,该框架需要能够记录用户的事件然后重播它们。我很好地使用围绕 P/Invoke 的 ManagedWinAPI 包装器(在 C# 中工作)来记录鼠标和键盘事件,这是有效的,但我认为为了使记录更有用,我需要更多地了解用户启动时发生的情况一个应用程序。

我不知道的是如何找到一个应用程序刚刚启动,它是什么应用程序。因此,假设用户启动了我的录音应用程序,然后转到开始菜单并单击“Paint”,我希望能够记录作为事件启动的“Paint.exe”(或者如果他们单击了传递一些参数的快捷方式这将是包含参数的快捷方式的值),因为如果我想在不同的机器上播放录音,菜单项可能位于不同的位置,因此鼠标事件可能具有欺骗性。

我需要遵循什么路线来获取这些数据?我一直没能找到术语,所以我什至没有真正把正确的东西放到搜索引擎中......

最佳答案

正确的方法是编写驱动程序并使用进程管理器回调在每次创建进程时获得通知。如果你不想这样做,你可以使用像 EasyHook 这样的托管 Hook 库,并 Hook NtCreateThread/NtCreateThreadEx。如果您不想那样做,那么您只需轮询新进程。

编辑:确定用户是否启动了特定进程也需要您遍历堆栈。在内核模式下,您可以使用 RtlWalkFrameChain,而在用户模式下,您可以使用 CaptureStackBackTrace。

编辑 2:参见 PsSetCreateProcessNotifyRoutinePsSetCreateProcessNotifyRoutineEx .

关于windows - 如何找到用户刚刚启动的可执行文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2030056/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com