当前位置: 首页 > 面试题库 >

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

邢弘业
2023-03-14
问题内容

我使用的朋友服务器仅允许一个用户从SSH登录,因此通常我只是以该用户身份登录,然后执行su -l myuser更改帐户的操作。我想使用Python自动执行一些无聊的工作,但是我遇到了问题。显然,我首先尝试过的Paramiko模块为每个命令调用了一个shell,所以这是不可能的。后来我尝试使用invoke_shell()克服它,但是仍然失败了(我想是因为更改用户也会更改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")

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))

su -c command 由于服务器系统不支持该选项,因此也不起作用。


问题答案:

首先是一般免责声明(针对那些偶然发现此问题的人):

  • 使用su不是正确的解决方案。su是一种旨在用于交互式用途而非自动化的工具。正确的解决方案是直接使用正确的帐户登录。

或至少使用无密码sudo

或者,您可以使用setuidright创建一个根所有者脚本。

另请参见在Linux上使用SSH以root身份自动执行命令。

  • 如果您坚持使用su,在大多数系统上,可以使用-cswitch su来指定命令:
    su -c "whoami" user
    

如果以上都不可行(并且您确实在尽力使管理员启用上述某些选项):

作为最后的选择,您可以将命令写到的标准输入中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()

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

请注意,您的问题不是关于要使用哪个SSH客户端库。 不管您使用Paramiko还是其他。这实际上是一个通用的SSH / shell问题。



 类似资料:
  • 问题内容: 我正在编写一个脚本来自动化Python中的某些命令行命令。目前,我正在打电话: 但是我需要在远程计算机上运行一些命令。手动地,我将使用ssh登录,然后运行命令。我将如何在Python中自动执行此操作?我需要使用(已知)密码登录到远程计算机,所以我不能只使用,我想知道是否应该使用一个模块? 问题答案:

  • 我试图在unix中使用JSCHSSH类(com.jcraft.jsch)执行一些工具。我的工具有一个选择菜单。我需要转到工具所在的文件夹,执行它并选择请求的选项。在每个命令之后,(cd,execute,…)我希望检查输出并检查状态代码(0/1)。我有下面的代码按预期执行它,但在这段代码中,我找不到一种方法来检查每个命令后的输出。 我无法找到一种方法,但我怎么能分开的命令,并打印他们一个接一个(在同

  • 问题内容: Scenerio:我想通过ssh从Java程序在远程机器上运行命令(我在开发机器上使用OpenSSH)。我也想通过传递密码来建立ssh连接,而不是像使用“期望”那样设置密钥。 问题:尝试执行“期望”之类的密码登录时,使用ProcessBuilder创建的流程似乎看不到密码提示。当运行常规的非ssh命令(例如’ls’)时,我可以获取流并与它们进行交互。我将标准错误和标准输出合并为一个流因

  • 我可以运行常规命令,如rm /home/user/Desktop/file但当我不能运行root命令。 我的目的是配置一个squid服务,运行如下命令:apt get install squid service squid start service 但是这些命令需要超级用户身份验证。 有人知道怎么修吗?谢啦

  • 问题内容: 我需要制作一个脚本来在Android设备上执行很多事情,我的设备已经扎根,当我进入外壳时,我可以给命令su,它可以工作,但是我需要传递以下命令: 当我在su起作用之前放置一些命令时,根据我的了解,su创建了一个立即返回的新shell,但是我需要在su shell上给出命令,我该怎么做? 问题答案: 好吧,如果您的手机已扎根,则可以使用“ su -c”命令运行命令。 这是build.pr

  • 远程服务器使用Duo2因素身份验证,并在使用SSH连接时提示您选择身份验证模式: 当我在终端中使用ssh时,我只需按1然后输入,得到我的手机的推送,在那里我证明了连接,然后我就登录了。 不幸的是,我无法在Python中做到这一点。下面是我尝试使用的代码: 如有任何帮助,将不胜感激。