使用phpseclib时出现意外行为

时间:2013-09-20 18:07:41

标签: php ssh rsa sftp phpseclib

我最近尝试实现phpseclib库登录到SFTP服务器以列​​出目录中的所有文件并下载它们。下载后,将它们移动到服务器上的其他目录。

我运气不好......所以直接从their site跟踪代码,但添加了日志记录。

set_include_path(get_include_path() . PATH_SEPARATOR . 'phpseclib');

require('Net\SSH2.php');
require('Crypt\RSA.php');   

define('NET_SSH2_LOGGING', 2);
$ssh = new Net_SSH2('host_name', 'port');
$key = new Crypt_RSA();
$key->loadKey(file_get_contents('path_to_rsa_file'));
if (!$ssh->login('username', $key)) {
  exit('Login Failed');
}

$ssh->exec("pwd");

导致以下错误:

Unable to request pseudo-terminal

不可否认,这是一个旧版本,我不确定究竟是哪一个,所以我想也许我应该更新。在通过composer提取最新版本并运行与上面相同的代码后,我没有收到任何错误,但我在日志中得到了这个:

<- NET_SSH2_MSG_USERAUTH_SUCCESS (since last: 0.1395, network: 0.1394s)

-> NET_SSH2_MSG_CHANNEL_OPEN (since last: 0.0006, network: 0.0005s)
00000000  00:00:00:07:73:65:73:73:69:6f:6e:00:00:00:00:7f  ....session.....
00000010  ff:ff:ff:00:00:40:00                             .....@.

<- NET_SSH2_MSG_CHANNEL_OPEN_CONFIRMATION (since last: 0.1232, network: 0.1231s)
00000000  00:00:00:00:00:00:00:00:ff:ff:ff:ff:00:00:80:00  ................

-> NET_SSH2_MSG_CHANNEL_REQUEST (since last: 0.0008, network: 0.0006s)
00000000  00:00:00:00:00:00:00:04:65:78:65:63:01:00:00:00  ........exec....
00000010  03:70:77:64                                      .pwd

<- NET_SSH2_MSG_CHANNEL_FAILURE (since last: 0.123, network: 0.1228s)
00000000  00:00:00:00                                      ....

任何人都有任何想法?我也尝试过使用SFTP类,但是其他问题失败了“注意:连接过早关闭”。

感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

看起来服务器不支持exec()read() / write()

可能会更好运

http://phpseclib.sourceforge.net/ssh/examples.html#interactive

至于SFTP ......我需要看日志才有任何想法。