PHP PHPSECLIB SFTP 使用私钥在 RSA 上给出错误无法实例化抽象类

问题描述 投票:0回答:2

我使用 Composer 安装了 phplibsec v3。 我的路径正确,现在不会给出任何错误,直到它命中 $rsa = new RSA()。 然后它出错并说: PHP 致命错误:未捕获错误:无法实例化抽象类 phpseclib3\C C:\Temp\PHPSCRIPTS\mmax_send_gl_file.php 中的 rypt\RSA:6 堆栈跟踪: #0 {主要} 扔在 C:\Temp\PHPSCRIPTS\mmax_send_gl_file.php 第 6 行

这是我的代码:

require 'c:\temp\php\vendor\autoload.php';
use phpseclib3\Net\SSH2;
use phpseclib3\Crypt\RSA;
use phpseclib3\Net\SFTP;
$rsa = new RSA();
$rsa->loadKey(file_get_contents('C:\temp\phpscripts\mmax.ppk'));
$sftp = new SFTP('sftp.server.com');
echo $sftp->get('test.txt');

如果我取出 $rsa 行,新的 SFTP 不会崩溃,但我需要私钥。 我尝试了几种变体,阅读了每一篇关于此的文章,并为此工作了几个小时。 我无法让它工作。 谁能告诉我我做错了什么?

另外,我可以使用 filezilla 和 sftp 登录 ftp 站点,并且工作正常。 我只是将主机放入并选择登录类型的密钥文件并将 ppk 内容加载到其中,没有任何问题。

我发现我需要做:

$rsa = PublicKeyLoader::load(file_get_contents('C:\temp\phpscripts\mmax.ppk'));

现在我的代码是:

require 'c:\temp\php\vendor\autoload.php';
use phpseclib3\Net\SSH2;
use phpseclib3\Crypt\PublicKeyLoader;
use phpseclib3\Net\SFTP;
$rsa = PublicKeyLoader::load(file_get_contents('C:\temp\phpscripts\mmax.ppk'));
$sftp = new SFTP('sftp.server.com');
if (!$sftp->login('username', $rsa)) {
   exit('Login Failed');
}
echo $sftp->get('test.txt');

它没有登录,我找不到有关如何使用私钥登录部分的文档。 另外,我不需要用户名。

php phpseclib
2个回答
3
投票

我能够度过这个难关。 有关更多背景信息,请参阅 neubert 的链接。 如上所述,我使用了 phpseclib v3。 rsa 的事情已经改变,现在使用 PublicKeyLoader::load。

它仍然无法连接,因为我没有提供用户名,并且我不确定如何处理以下内容中的“用户名”:

if (!$sftp->login('username', $rsa)) {

声明。 我检查了 filezilla 日志,它正在将我的 ppk 文件中的内容发送到 comment: 行,尽管用户名不明显。

我将用户名更改为评论字段中的值并修复了该问题。 不确定这是否“正常”,但 filezilla 知道如何处理它。

这是最终的工作脚本,没有实际的服务器目标:

$arr = getopt("f:");
$file = $arr['f'];
require 'c:\temp\php\vendor\autoload.php';
use phpseclib3\Net\SSH2;
use phpseclib3\Crypt\PublicKeyLoader;
use phpseclib3\Net\SFTP;
$rsa = PublicKeyLoader::load(file_get_contents('C:\temp\keys\mmax.ppk'));
$sftp = new SFTP('sftp.server.com');
if (!$sftp->login('username_from_ppk_comment_line', $rsa)) {
  exit('Login Failed');
}
$sftp->put($file,'c:\\temp\\EXPORT\\'.$file, SFTP::SOURCE_LOCAL_FILE);
echo 'done';

这是在 Windows 服务器上从命令提示符运行它。 希望这可以节省其他人的时间。 总是那“一件事”花费的时间最长。


0
投票

描述

pem
键,如果有人会像我一样搜索这个。 像这样安装
phpseclib

composer.phar require phpseclib

在选择列表中选择

phpseclib/phpseclib

连接脚本代码:

use phpseclib3\Crypt\PublicKeyLoader;
use phpseclib3\Net\SFTP;

$addr = '192.168.192.168';
$username = 'root';
$pempath =  'my.pem';
$keypass = 'pempass'; # Don't keep password in code like this! This is for example only! Use at least .env file for stuff like this
# Don't keep password in code like this! This is for example only! Use at least .env file for stuff like this
# Don't keep password in code like this! This is for example only! Use at least .env file for stuff like this
$sftp = new SFTP($addr);
$rsa = PublicKeyLoader::load(file_get_contents($pempath), $keypass);

try {
    $r = $sftp->login($username, $rsa); # login via sftp
} catch(\Exception $e){
    print_r($e->getMessage());
    print_r($e);
    die;
}

$files_and_folders = $sftp->nlist(); # now you can list what's in here
print_r($files_and_folders);
© www.soinside.com 2019 - 2024. All rights reserved.