为什么paramiko返回\r\n作为换行符而不是\n?

5

我正在使用一个名为“paramiko”的Python SSH库。 使用方法如下:

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(host, username=user_name, password=password)
chan = ssh_pool[host].get_transport().open_session()
chan.exec_command(SOME_COMMAND)

由于我需要在sudo中执行某些命令,所以在执行exec_command前需要调用chan.get_pty()来确保有一个可用的tty。

然后我发现,在调用了get_pty()之后,从远程服务器返回的标准输出使用\r\n代替\n作为换行符。

例如:

>>> chan = ssh.get_transport().open_session()
>>> chan.exec_command("echo hello world")
>>> chan.recv(1000)
b'hello world\n'

在调用get_pty()之后:

>>> chan = ssh.get_transport().open_session()
>>> chan.get_pty()
>>> chan.exec_command("echo hello world")
>>> chan.recv(1000)
b'hello world\r\n'

我进行了一些网络搜索,但没有找到任何与 pty / tty / newline / \r\n 相关的内容。

我担心此更改可能会引起什么问题。

为什么 paramiko 返回 \r\n 而不是 \n 作为换行符?


为什么你要这么担心呢?这只是你运行命令后返回值字符串中的换行符。当然,你需要对其进行处理,但可以将其分割成一个\n列表并替换\r,或者同时替换\r\n:https://dev59.com/PmQn5IYBdhLWcg3wzZtU - jhoepken
@JensHöpken 因为我处理了一堆环境非常不同的服务器。我已经考虑到同时处理 \r\n 和 \n。但是我还担心如果我无法找出可能引起这个问题的原因,那么将来可能会出现某种未知的问题。 - lxohi
1个回答

5
因为这是新行在伪终端中的翻译方式。 \r 是回车符,将光标移动到第1列,\n 是换行符,将光标向下移动一行。
终端默认启用 onlcr 翻译标志。从 stty 手册页面可以看到:

[-]onlcr

换行符执行回车符

您还可以在 stty -a 的输出中看到此标志已启用,即在第3个最后一行上没有 -
% stty -a
speed 38400 baud; rows 46; columns 79; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;
eol2 = <undef>; swtch = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R;
werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;
-parenb -parodd -cmspar cs8 -hupcl -cstopb cread -clocal -crtscts
-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr icrnl ixon ixoff
-iuclc -ixany -imaxbel iutf8
opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0 bs0 vt0 ff0
isig icanon iexten echo echoe echok -echonl -noflsh -xcase -tostop -echoprt
echoctl echoke

您可以使用stty -onlcr禁用此设置,但通常情况下它的存在不应该是一个问题;如果您怀疑某些二进制数据可能会损坏,那么无论如何都不应该使用pty。
如果只是一个单一的命令,那么通过SSH发送明文密码并不能增加多少安全性;如果有人现在可以访问您的远程帐户,他们不仅可以无限制地访问该计算机上的root,还会知道您的密码。最好让ssh到root,然后使用"强制命令"来运行这个命令,或者编辑/etc/sudoers以便从该帐户执行此单个命令时不需要密码

谢谢您的回答和建议!我会尝试的。 - lxohi

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接