Сбой соединения SFTP с модулем Perl "Net :: SFTP" - PullRequest
1 голос
/ 05 мая 2019

Я пытаюсь подключиться к SFTP-серверу с помощью Perl, но получаю следующую ошибку подключения: Permission denied at /app/perl-5.24.3/lib/site_perl/5.24.3/Net/SFTP.pm line 63.

Код моего соединения 'sftp_test2.pl':

use strict;
use warnings;

use Net::SFTP;

my $server   = 'downloads-server';
my $user     = 'user';
my $port     = "10022";
my $password = '';

my %args = (
     user => "$user",
     port => "$port",
     ssh_args => {
         user => "$user",
         identity_files => [ 'path/sftp_download'],
         port => "$port",
         protocol=>'2,1',
         debug => 1,
     }
);

my $sftp=Net::SFTP->new($server, %args) or die "could not open connection to $server\n";

исполнение:

$>perl sftp_test2.pl
Reading configuration data path/home/.ssh/config
Reading configuration data /etc/ssh_config
Connecting to downloads-server, port 10022.
Remote version string: SSH-2.0-CrushFTPSSHD
Remote protocol version 2.0, remote software version CrushFTPSSHD
Net::SSH::Perl Version 2.14, protocol version 2.0.
No compat match: CrushFTPSSHD.
Connection established.
Sent key-exchange init (KEXINIT), waiting for response.
Using diffie-hellman-group-exchange-sha256 for key exchange
Host key algorithm: ssh-rsa
Algorithms, c->s: aes256-ctr hmac-sha2-512-etm@openssh.com none
Algorithms, s->c: aes256-ctr hmac-sha2-512-etm@openssh.com none
Entering Diffie-Hellman Group Exchange.
SSH2_MSG_KEX_DH_GEX_REQUEST(2048<4096<8192) sent
Sent DH Group Exchange request, waiting for reply.
Received 4096 bit DH Group Exchange reply.
Generating new Diffie-Hellman keys.
Entering Diffie-Hellman key exchange.
Sent DH public key, waiting for reply.
Received host key, type 'ssh-rsa'.
Host 'downloads-server' is known and matches the host key.
Verifying server signature.
Send NEWKEYS.
Waiting for NEWKEYS message.
Enabling encryption/MAC/compression.
Sending request for user-authentication service.
Service accepted: ssh-userauth.
Trying empty user-authentication request.
Authentication methods that can continue: password,publickey,keyboard-interactive.
Next method to try is password.
Trying password authentication.
Will not query passphrase in batch mode.
Authentication methods that can continue: password,publickey,keyboard-interactive.
Next method to try is password.
Trying password authentication.
Will not query passphrase in batch mode.
Authentication methods that can continue: password,publickey,keyboard-interactive.
Next method to try is password.
Trying password authentication.
Will not query passphrase in batch mode.
Authentication methods that can continue: password,publickey,keyboard-interactive.
Next method to try is password.
Next method to try is publickey.
Publickey: testing agent key 'my-server'
Authentication methods that can continue: password,publickey,keyboard-interactive.
Next method to try is password.
Next method to try is publickey.
Publickey: testing agent key 'path/home/.ssh/id_rsa'
Authentication methods that can continue: password,publickey,keyboard-interactive.
Next method to try is password.
Next method to try is publickey.
Trying pubkey authentication with key file 'path/sftp_download'
Authentication methods that can continue: password,publickey,keyboard-interactive.
Next method to try is password.
Next method to try is publickey.
Permission denied at /app/perl-5.24.3/lib/site_perl/5.24.3/Net/SFTP.pm line 63.

Я думал, что это связано с моим закрытым ключом, но я могу подключиться с помощью команды unix:

sftp -oPort = 10022 -oIdentityFile = путь / sftp_download user @ downloads-сервер
Подключение к серверу загрузок ...
sftp>

Я пытался найти решение во многих статьях, а также пробовал несколько вариантов кода, но безуспешно.

Я что-то не так делаю? Это известная ошибка? любой обходной путь? Как я могу отладить его, чтобы найти причину (я не очень хорошо знаком с SSH / FTP).

EDIT : Я подозревал, что это может быть связано с несколькими неудачными попытками подключения с паролем, поэтому я удалил аутентификацию по паролю из "% AUTH_MAP" в файле "app / perl-5.24.3 / lib / site_perl / 5.24.3 / x86_64-linux / Net /SSH/Perl/AuthMgr.pm "и подключился как положено! Есть ли способ принудительного использования аутентификации только по первому ключу?

Заранее спасибо! Mike

1 Ответ

0 голосов
/ 07 мая 2019

Код для отключения аутентификации по паролю (только ключ аутентификации):

ssh_args => {
  user    => $user,
  options => [ 'PasswordAuthentication no' ],
  identity_files => [ 'path/sftp_download'],
  port     => $port,
  protocol =>'2,1',
  debug    => 1,
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...