Python telnetlib read_until returns cut off string

谁说胖子不能爱 提交于 2019-12-24 00:57:27

问题


[Python telnetlib read_until recv problem]

"read_until" function returns cut off string with long commands.
The commands ran perfectly, but it does not show full texts.
How can I fix this? Please help.

# my code

tn = telnetlib.Telnet(ip, 23, 5)
prompt = ']# '
tn.write('echo "this is a long command for the test purpose... > test.txt"\n')
print tn.read_until(prompt, 1)

# debug output

Telnet(192.168.220.4,23): send 'echo "this is a long command for the test purpose... > test.txt"\n'
Telnet(192.168.220.4,23): recv 'echo "this is a l'
Telnet(192.168.220.4,23): recv 'ong command for the test purpose... > te\r\x00<his is '
Telnet(192.168.220.4,23): recv 'a long command for the test purpose... > tes '
Telnet(192.168.220.4,23): recv ' \x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x08\x0 8t.txt"'
Telnet(192.168.220.4,23): recv '\r\nthis is a long command for the test purpose... >'
Telnet(192.168.220.4,23): recv ' test.txt\r\n[root@RHEL6-5 tmp]# '

# real output

<his is a long command for the test purpose... > test.txt"
this is a long command for the test purpose... > test.txt
[root@RHEL6-5 tmp]#


回答1:


The issue appears to be occurring due to line-wrapping. I found a solution where setting the window size width to near the max value allows long lines to be received without line-wrapping applied by the telnet server.

(See the Window Size Option RFC for details on setting the option https://www.ietf.org/rfc/rfc1073.txt )

import telnetlib
import struct
from telnetlib import DO, DONT, IAC, WILL, WONT, NAWS, SB, SE

MAX_WINDOW_WIDTH = 65000  # Max Value: 65535
MAX_WINDOW_HEIGHT = 5000


def set_max_window_size(tsocket, command, option):
    """
    Set Window size to resolve line width issue
    Set Windows size command: IAC SB NAWS <16-bit value> <16-bit value> IAC SE
    --> inform the Telnet server of the window width and height.
    Refer to https://www.ietf.org/rfc/rfc1073.txt
    :param tsocket: telnet socket object
    :param command: telnet Command
    :param option: telnet option
    :return: None
    """
    if option == NAWS:
        width = struct.pack('H', MAX_WINDOW_WIDTH)
        height = struct.pack('H', MAX_WINDOW_HEIGHT)
        tsocket.send(IAC + WILL + NAWS)
        tsocket.send(IAC + SB + NAWS + width + height + IAC + SE)
    # -- below code taken from telnetlib source
    elif command in (DO, DONT):
        tsocket.send(IAC + WONT + option)
    elif command in (WILL, WONT):
        tsocket.send(IAC + DONT + option)

ip = 'x.x.x.x'
tn = telnetlib.Telnet(ip, 23, timeout=5)
tn.set_option_negotiation_callback(set_max_window_size)

tn.write('echo "this is a long command for the test purpose... > test.txt"\n')

prompt = ']# '
print tn.read_until(prompt, timeout=1)



回答2:


Working for me.

def set_max_window_size(tsocket, command, option):
"""
Set Window size to resolve line width issue
Set Windows size command: IAC SB NAWS <16-bit value> <16-bit value> IAC SE
--> inform the Telnet server of the window width and height.
Refer to https://www.ietf.org/rfc/rfc1073.txt
:param tsocket: telnet socket object
:param command: telnet Command
:param option: telnet option
:return: None
"""
if option == NAWS:
    naws_command = struct.pack('!BBBHHBB',
    255, 250, 31, # IAC SB NAWS
    50, 100, #width, height
    255, 240) # IAC SE
    tsocket.send(naws_command)
# -- below code taken from telnetlib source
elif command in (DO, DONT):
    tsocket.send(IAC + WONT + option)
elif command in (WILL, WONT):
    tsocket.send(IAC + DONT + option)

ip = 'x.x.x.x'
tn = telnetlib.Telnet(ip, 23, timeout=5)
socket = tn.get_socket()
tn.set_option_negotiation_callback(set_max_window_size)

tn.write('echo "this is a long command for the test purpose... > test.txt"\n')

prompt = ']# '
print tn.read_until(prompt, timeout=1)


来源:https://stackoverflow.com/questions/38288887/python-telnetlib-read-until-returns-cut-off-string

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!