【问题标题】:What does CreateFile("CONIN$" ..) do?CreateFile("CONIN$" ..) 做什么?
【发布时间】:2008-12-18 07:58:16
【问题描述】:

我正在破解 plink 的源代码,以使其与 unison 兼容。

如果你不知道,unison是一个文件同步工具,它运行“ssh”命令连接远程服务器,但是windows没有ssh.exe;有 plink,它非常接近但不够接近(它的行为不像 unison 期望的那样),所以人们通常在它周围做包装,like this one

其中一个问题是 unison 期望密码提示打印到 stderr(但 plink 将其打印到 stdout,并导致 unison 混淆),所以我想,嗯,应该足够简单,破解我的 thru plink 代码并使其将提示打印到标准输出。所以我破解了我的方式并做到了。

下一个问题:我无法响应提示!!无论我输入什么,它都没有效果。

获取输入的代码大致是这样的:

hin = GetStdHandle(STD_INPUT_HANDLE);
....
r = ReadFile(hin, .....);

我不确定为什么要这样做,但我不是为 Windows 设计命令行工具的专家,所以我知道什么!但我认为在设置输入句柄时缺少一些东西。

我查看了above wrapper tool 的源代码,我看到了这个: hconin=CreateFile("CONIN$",GENERIC_READ|GENERIC_WRITE,FILE_SHARE_READ,0,OPEN_EXISTING,0,0)

我试试看(只是为了好玩)

hin=CreateFile("CONIN$",GENERIC_READ|GENERIC_WRITE,FILE_SHARE_READ,0,OPEN_EXISTING,0,0);
....
r = ReadFile( hin ...... )

令人惊讶的是它的工作原理!我现在可以响应提示了!

这是为什么?什么是“CONIN$”?为什么它与STD_INPUT_HANDLE 不同?

我可以“猜测”FILE_SHARE_READOPEN_EXISTING 在其中发挥作用(因为 ssh 是从另一个进程中运行的),但我想了解这里发生了什么,并确保这段代码没有一些不需要的副作用或安全漏洞或类似的可怕的东西!

【问题讨论】:

    标签: winapi input pipe plink


    【解决方案1】:

    CONIN$ 是控制台输入设备。通常,标准输入是一个打开的文件句柄,但如果标准输入由于某种原因被重定向,那么使用CONIN$ 将允许您访问控制台,尽管重定向。 Reference.

    【讨论】:

    • 这就像在 Unix 中打开 /dev/console。 :-)
    • 它更像/dev/tty,指向进程的控制终端,而/dev/console通常是物理控制台(串口或tty1)。
    • @Andrew:真的吗?如果您重定向了标准输入,/dev/stdin 将获得重定向的文件。我认为CONIN$ 应该到达终端,不管任何重定向。
    • 你是对的——在我找到答案的乐观态度中,我误读了 CONIN$ 的作用。它似乎和 CON 一样,就像 /dev/tty 而不是 /dev/stdin。我已经删除了我的评论。 (Windows 是否有 /dev/stdin 等效项?)
    猜你喜欢
    • 2018-12-29
    • 1970-01-01
    • 2020-04-01
    • 1970-01-01
    • 2014-04-29
    • 1970-01-01
    • 1970-01-01
    • 2016-11-20
    • 1970-01-01
    相关资源
    最近更新 更多