我使用 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');
它没有登录,我找不到有关如何使用私钥登录部分的文档。 另外,我不需要用户名。
我能够度过这个难关。 有关更多背景信息,请参阅 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 服务器上从命令提示符运行它。 希望这可以节省其他人的时间。 总是那“一件事”花费的时间最长。
描述
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);