本文介绍了如何向进程发送密钥而不是字符?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

System.Diagnostics.Process 公开了一个名为 StandardInput 的 StreamWriter,据我所知,它只接受字符.

System.Diagnostics.Process exposes a StreamWriter named StandardInput, which accepts only characters as far as I know.

但我也需要发送击键,有些击键不能很好地映射到字符.

But I need to send keystrokes as well, and some keystrokes don't map well to characters.

我该怎么办?

推荐答案

您正在将输入流与控制信号混合.正如您所知,控制台进程有一个默认输入流,您可以使用 StandardInput 控制它.但是 Ctrl-C 和 Ctrl-Break 不是通过此流发送到进程的字符,而是控制信号,进程使用已注册的信号处理程序接收,参见 CTRL+C 和 CTRL+BREAK 信号:

You are mixing input streams with control signals. A console process has a default input stream which you can control with the StandardInput, as you already know. But Ctrl-C and Ctrl-Break are not characters sent to the process through this stream, but instead they are instead control signals that the process receives using the registered signal handlers, see CTRL+C and CTRL+BREAK Signals:

默认情况下,当控制台窗口具有键盘焦点,CTRL+C 或CTRL+BREAK 被视为信号(SIGINT 或 SIGBREAK) 而不是键盘输入.

要向进程发送虚假信号,您可以使用 GenerateConsoleCtrlEvent 并发送 CTRL_C_EVENTCTRL_BREAK_EVENT.此 API 没有 .Net 等效项,因此您必须对其进行 PInvoke.

To send fake signals to a process you can use GenerateConsoleCtrlEvent and send either CTRL_C_EVENT or CTRL_BREAK_EVENT. This API has no .Net equivalent, so you have to PInvoke it.

要从 .NET 使用它,您只需包含函数定义:

To use it from .NET you simply need to include the function definition:

const int CTRL_C_EVENT = 0;
const int CTRL_BREAK_EVENT = 1;

[DllImport("kernel32.dll")]
static extern bool GenerateConsoleCtrlEvent(
    uint dwCtrlEvent,
    uint dwProcessGroupId);

这篇关于如何向进程发送密钥而不是字符?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

07-25 05:05