Python telnetlib 客户端似乎没有打开到服务器的 telnet 连接

Python telnetlib client doesn't appear to be opening telnet connection to server

我正在尝试打开一个 telnet 连接,写入一个字符串,然后从 Python 中的 telnet 服务器打印所有内容。我想我遗漏了一些明显的东西,因为文档看起来很不言自明,并且在终端中做我认为完全相同的事情工作正常。

这里是 Python 代码:

import telnetlib

telnet = telnetlib.Telnet()
telnet.open('192.168.1.128', 9801, 10)
telnet.write("SYSTEM_CAL")

print(telnet.read_all())

这在 10 秒后超时/没有成功连接到我假设的服务器。这是输出:

Traceback (most recent call last):
  File "/Volumes/Work/Scripting/Telnet Test/main.py", line 9, in <module>
    print(telnet.read_all())
  File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/telnetlib.py", line 385, in read_all
    self.fill_rawq()
  File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/telnetlib.py", line 576, in fill_rawq
    buf = self.sock.recv(50)
socket.timeout: timed out

在下图中,我在终端中连接到同一台服务器,一切正常。最后,我给出服务器执行的 "DISCONNECT" 命令,这就是连接关闭的原因。

我错过了什么吗?为什么这在终端而不是 Python 中有效?

我想你发送命令的时间太早了,接收端忽略了它。尝试先阅读横幅:

print(telnet.read_until("Welcome."))
telnet.write("SYSTEM_CAL")
print(telnet.read_all())

编辑:

我还注意到您在 "SYSTEM_CAL" 末尾没有行终止序列。我假设,在交互式会话中,您在键入 "SYSTEM_CAL" 后按 ↵ ENTER。如果是这种情况,您需要在 write() 调用的末尾添加 \n

telnet.write("SYSTEM_CAL\n")

根据您问题之外的其他因素,您可能需要以下其中一项:

telnet.write("SYSTEM_CAL\r")
telnet.write("SYSTEM_CAL\r\n")