我正在使用名为“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 avaliable。
我在调用get_pty()后发现,stdout从远程服务器返回,使用\ 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?
返回答案 0 :(得分:3)
因为这是(伪)终端翻译换行符的方式。 \r
是将光标移动到第1列的回车符,\n
是将光标向下移动1的换行符。
默认情况下,终端启用了onlcr
转换标志。来自stty
手册页:
[-]onlcr
换行执行回车
您还可以在-
的输出中看到此标记已启用,即前面(第3行最后一行)没有stty -a
。
% 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是更好,让root用"forced commands"或edit /etc/sudoers
so that no password is required for this single command from this account运行这个1命令。