我有一个subprocess.Popen
用于启动目标程序的 python 脚本:一个网络服务器。我想与目标进行交互,所以我将stdin
,stdout
和分配stderr
给管道,现在我可以读写它们了。
现在,网络服务器链接 OpenSSL 库以进行 TLS 处理。作为 TLS 处理的一部分,它会打开证书并提示输入密码。通常,在输入密码并按下回车键后,网络服务器就会开始服务。现在,您可能已经猜到了,我想从 python 脚本中输入此密码。通常,我需要做的是写入服务器的stdin
. 但是,有一个问题。当 OpenSSL 提示并读取密码时,它不使用stdin
/ stdout
。它打开/dev/tty
并使用它。结果,我必须输入密码并手动输入。
下图演示了这种情况。
lsof下面,您可以看到服务器输出的片段:
memcached 25279 USER 0r FIFO 0,13 0t0 7771739 pipe
memcached 25279 USER 1w FIFO 0,13 0t0 7771740 pipe
memcached 25279 USER 2w FIFO 0,13 0t0 7771740 pipe
memcached 25279 USER 3r REG 8,1 3414 3414276 ....key.pem
memcached 25279 USER 4r CHR 5,0 0t0 13 /dev/tty
memcached 25279 USER 5w CHR 5,0 0t0 13 /dev/tty
有没有办法拦截对/dev/tty服务器的调用,以便我可以直接从脚本写入它?
当年话下
相关分类