使用 Python 在 SSH 中使用“su -l”执行命令

w1k*_*l4s 2 python linux ssh paramiko fabric

我使用的朋友服务器只允许一个用户从 SSH 登录,所以通常我只是以该用户身份登录,然后su -l myuser更改帐户。我想使用 Python 自动化一些无聊的东西,但我遇到了问题。显然,我首先尝试的 Paramiko 模块为每个命令调用一个 shell,所以这是不可能的。后来我尝试使用invoke_shell()来克服这个问题,但它仍然失败(我认为这是因为更改用户也会更改外壳)。

在那之后,我发现了 Fabric 模块,但我能做的最好的事情是在正确的用户登录的情况下打开 SSH shell,但没有选择从代码运行任何命令。

有没有办法做到这一点?最终目标可能是这样的:

ssh.login(temp_user, pass)
ssh.command("su -l myuser")
expect("Password: ", ssh.send("mypass\n")
ssh.command("somescript.sh > datadump.txt")
Run Code Online (Sandbox Code Playgroud)

使用sudo是不可能的,以及添加无密码登录。

正如这里所建议的那样,我尝试使用 Paramiko 的代码:

import paramiko

host = "hostip"
user = "user"
user_to_log = "myuser"
password = "pass"
password_to_log = "mypass"

login_command = "su -l " + user_to_log

ssh = paramiko.SSHClient()
ssh.load_system_host_keys()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostip, username=user, 
    password=password)    

transport = ssh.get_transport()
session = transport.open_session()
session.set_combine_stderr(True)
session.get_pty()


session.exec_command("su -l " + user_to_log)
stdin = session.makefile('wb', -1)


stdin.write(password_to_log +'\n')
stdin.flush()

session.exec_command("whoami")
stdout = session.makefile('rb', -1)

for line in stdout.read().splitlines():        
    print('host: %s: %s' % (host, line))
Run Code Online (Sandbox Code Playgroud)

su -c command 也不会工作,因为服务器系统不支持该选项。

Mar*_*ryl 5

首先是一般免责声明(对于偶然发现这个问题的其他人):


如果以上都不可行(并且您真的很努力地让管理员启用上述某些选项):

作为最后的选择,您可以将命令写入 的标准输入,su就像您已经编写密码一样(另一件事不要做):

stdin, stdout, stderr = session.exec_command("su -l " + user_to_log)

stdin.write(password_to_log + '\n')
stdin.flush()

command = 'whoami'
stdin.write(command + '\n')
stdin.flush()
Run Code Online (Sandbox Code Playgroud)

(另请注意,调用 是多余的makefile,因为exec_command已经返回了)

请参阅在 Python Paramiko 中的 SSH 服务器上的辅助 shell/命令中执行(子)命令


请注意,您的问题不是关于使用哪个 SSH 客户端库。使用 Paramiko 或其他都没有关系。这实际上是一个通用的 SSH/Linux/shell 问题。