<?php
$ssh = ssh2_connect('domain.tld');
ssh2_auth_password($ssh, 'username', 'password');
$shell = ssh2_shell($ssh);
echo fread($shell, 1024*1024);
fwrite($shell, "sudo ls -la\n");
$output = fread($shell, 1024*1024);
echo $output;
if (preg_match('#[pP]assword[^:]*:#', $output)) {
fwrite($shell, "password\n");
echo fread($shell, 1024*1024);
}
所有这一切都是显示横幅和提示。它实际上并没有给我ls -la命令的输出。在phpseclib上它运作得很好。
有什么想法吗?
答案 0 :(得分:4)
我写了一个SSH包装器(https://github.com/bubba-h57/PHP-SSH2)来促进我自己的许多需要SSH到远程服务器的PHP脚本,并经常遇到这个问题。
我用这个咒语解决了它:
echo <password> | sudo -S <command>
您可能会看起来像这样:
fwrite($shell, "echo $mySudoPassword | sudo -S ls -la\n");
我每次使用sudo时都会输入密码,无论我认为我是否需要它。
使用我自己的包装器,它看起来像:
require_once 'SSH2.php';
// Test Unix
$username = 'someuser';
$password = 'somepwd';
$host = 'somenixhost.com';
$port = 22;
$ssh2 = new My_SSH2($host, $port);
$ssh2->authPassword( $username, $password);
$ssh2->setPrompt(':~#'); // Set initial expected prompt
$ssh2->openShell();
$ssh2->setPrompt("MYCUSTOMSSHPROMPT> "); // Create a unique, easily found prompt
$ssh2->exec("PS1='MYCUSTOMSSHPROMPT> '"); // Execute the command.
echo $ssh2->exec('cd /var/www') . "\n"; // Change directories.
echo $ssh2->exec("echo $password | sudo -S ls -la\n") . "\n"; // Print LS
echo "\n===================Begin History=============\n";
echo $ssh2->getHistory();
$ssh2->disconnect();
echo "\n===================end=============\n";
exit;