Net :: FTPSSL给出错误,命令行[0](0,1)()在行上出现意外的EOF…

问题描述 投票:1回答:1

我正在尝试在ubuntu服务器上使用Perl和Net :: FTPSSL将本地文件上传到外部托管的Web服务器。使用TLS可以正常登录,但是在尝试ls远程服务器上的文件时失败。错误是“命令通道[0](0,1)()在行上出现意外的EOF…”。

如果使用putget尝试发送/获取文件,则会出现相同的错误。但是,如果我尝试使用普通的unix FTP客户端进行交互,则可以正常工作。

知道如何解决它?

2020年5月21日更新-我已经更新了代码和输出文件,在下面提供了更多调试日志记录

代码非常简单。像这样:

#!/usr/bin/perl
use strict;
use IO::Socket::SSL;
use Net::FTPSSL;

$IO::Socket::SSL::DEBUG = 3;
$Net::SSLeay::trace = 4;

my $file=$ARGV[0];
my $dir=$ARGV[1];

#----------------------------------------------------------------------
#1st try
if (1) {
    #print "$server $username $password\n";
    my $server="hubble.krystal.co.uk";
    my $fields = `cat nickdata`;
    chomp($fields);
    my ($username, $password) = split /\t/, $fields;
    my $rc;

    open (STDERR, ">FTPLog.txt");

    my $ftp = Net::FTPSSL->new($server,
              Encryption => EXP_CRYPT,
              Debug => 1,
              OverrideHELP => 0,
              Croak => 1);
    $ftp->trapWarn();

    $ftp->login($username, $password) || die "Cannot login\n";

    $ftp->pwd;

    $ftp->feat();
    $ftp->noop();
    $ftp->supported("MLSD");
    $ftp->supported("NLST");
    $ftp->quot("OPTS", "UTF8 ON");
    $ftp->quot("TYPE", "I");
    $ftp->quot("SYST");

    #these fail
    #$ftp->nlst();
    $ftp->list();
    exit;
}

日志文件现在包括SSL调试日志记录如下:

Net-FTPSSL Version: 0.42
IO-Socket-SSL Version: 2.068
Net-SSLeay Version: 1.84
IO-Socket-INET Version: 1.41
IO-Socket-INET6 might not be installed.
IO-Socket-IP Version: 0.39
IO Version: 1.42
Socket Version: 2.029

IPv6 support available via IO::Socket::IP (0.39)  Key: (Family)

Perl: 5.026001  [5.26.1],  OS: linux

***** IPv6 not yet supported in Net::FTPSSL! *****

Server (port): hubble.krystal.co.uk (21)

Keys: (OverrideHELP), (Encryption), (Debug), (Croak)
Values: (0), (E), (1), (1)

SKT <<< 220---------- Welcome to Pure-FTPd [privsep] [TLS] ----------
SKT <<< 220-You are user number 1 of 50 allowed.
SKT <<< 220-Local time is now 19:54. Server port: 21.
SKT <<< 220-This is a private system - No anonymous login
SKT <<< 220-IPv6 connections are also welcome on this server.
SKT <<< 220 You will be disconnected after 15 minutes of inactivity.
SKT >>> AUTH TLS
SKT <<< 234 AUTH TLS OK.
DEBUG: .../IO/Socket/SSL.pm:3010: new ctx 94714584143456
DEBUG: .../IO/Socket/SSL.pm:1620: start handshake
DEBUG: .../IO/Socket/SSL.pm:1177: global error: Undefined SSL object
DEBUG: .../IO/Socket/SSL.pm:787: ssl handshake not started
DEBUG: .../IO/Socket/SSL.pm:829: using SNI with hostname hubble.krystal.co.uk
DEBUG: .../IO/Socket/SSL.pm:880: set socket to non-blocking to enforce timeout=120
DEBUG: .../IO/Socket/SSL.pm:894: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:897: done Net::SSLeay::connect -> -1
DEBUG: .../IO/Socket/SSL.pm:907: ssl handshake in progress
DEBUG: .../IO/Socket/SSL.pm:917: waiting for fd to become ready: SSL wants a read first
DEBUG: .../IO/Socket/SSL.pm:937: socket ready, retrying connect
DEBUG: .../IO/Socket/SSL.pm:894: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:897: done Net::SSLeay::connect -> -1
DEBUG: .../IO/Socket/SSL.pm:907: ssl handshake in progress
DEBUG: .../IO/Socket/SSL.pm:917: waiting for fd to become ready: SSL wants a read first
DEBUG: .../IO/Socket/SSL.pm:937: socket ready, retrying connect
DEBUG: .../IO/Socket/SSL.pm:894: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:897: done Net::SSLeay::connect -> -1
DEBUG: .../IO/Socket/SSL.pm:907: ssl handshake in progress
DEBUG: .../IO/Socket/SSL.pm:917: waiting for fd to become ready: SSL wants a read first
DEBUG: .../IO/Socket/SSL.pm:937: socket ready, retrying connect
DEBUG: .../IO/Socket/SSL.pm:894: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:897: done Net::SSLeay::connect -> -1
DEBUG: .../IO/Socket/SSL.pm:907: ssl handshake in progress
DEBUG: .../IO/Socket/SSL.pm:917: waiting for fd to become ready: SSL wants a read first
DEBUG: .../IO/Socket/SSL.pm:937: socket ready, retrying connect
DEBUG: .../IO/Socket/SSL.pm:894: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:897: done Net::SSLeay::connect -> -1
DEBUG: .../IO/Socket/SSL.pm:907: ssl handshake in progress
DEBUG: .../IO/Socket/SSL.pm:917: waiting for fd to become ready: SSL wants a read first
DEBUG: .../IO/Socket/SSL.pm:937: socket ready, retrying connect
DEBUG: .../IO/Socket/SSL.pm:894: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:897: done Net::SSLeay::connect -> 1
DEBUG: .../IO/Socket/SSL.pm:952: ssl handshake done

Object HASH Details ... (SSL:arguments - E)
  SSL_hostname ==> hubble.krystal.co.uk
  SSL_verify_mode ==> 0
  SSL_version ==> TLSv12
  Timeout ==> 120


Object Net::FTPSSL Details ... (hubble.krystal.co.uk:21 - E)
  _FTPSSL_arguments ==> HASH(0x562475877a30)
      -- Croak ===> 1
      -- Crypt ===> E
      -- FixGetTs ===> 0
      -- FixPutTs ===> 0
      -- Host ===> hubble.krystal.co.uk
      -- OverrideHELP ===> 0
      -- Pret ===> 0
      -- Timeout ===> 120
      -- buf_size ===> 10240
      -- data_prot ===> P
      -- dcsc_mode ===> 1
      -- debug ===> 1
      -- debug_extra ===> 0
      -- debug_no_help ===> 0
      -- help_cmds_found ===> HASH(0x5624758b7740)
      -- help_cmds_msg ===> 214 HELP Command Overridden by request.
      -- help_cmds_no_syntax_available ===> 1
      -- last_ftp_msg ===> 234 AUTH TLS OK.
      -- myContext ===> HASH(0x5624758b7b18)
          -- SSL_reuse_ctx ----> IO::Socket::SSL::SSL_Context=HASH(0x562475b19828)
              -- context ++++> 94714584143456
              -- ocsp_cache ++++> (undef)
              -- ocsp_mode ++++> 0
              -- verify_mode ++++> 0
      -- mySocketOpts ===> HASH(0x562475384650)
          -- PeerAddr ----> hubble.krystal.co.uk
          -- PeerPort ----> 21
          -- Proto ----> tcp
          -- Timeout ----> 120
      -- start_SSL_opts ===> HASH(0x5624758775e0)
          -- SSL_hostname ----> hubble.krystal.co.uk
          -- SSL_verify_mode ----> 0
          -- SSL_version ----> TLSv12
          -- Timeout ----> 120
      -- trace ===> 0
      -- type ===> A
  _SSL_arguments ==> HASH(0x562475b198b8)
      -- PeerAddr ===> 77.72.1.20
      -- PeerPort ===> 21
      -- Proto ===> tcp
      -- SSL_check_crl ===> 0
      -- SSL_cipher_list ===> ECDHE-ECDSA-AES128-GCM-SHA256 ECDHE-RSA-AES128-GCM-SHA256 DHE-RSA-AES128-GCM-SHA256 ECDHE-ECDSA-CHACHA20-POLY1305 ECDHE-RSA-CHACHA20-POLY1305 ECDHE-ECDSA-AES256-SHA ECDHE-RSA-AES256-SHA DHE-RSA-AES256-SHA ECDHE-ECDSA-AES128-SHA ECDHE-RSA-AES128-SHA DHE-RSA-AES128-SHA AES128-GCM-SHA256 AES256-SHA AES128-SHA DES-CBC3-SHA ECDHE-RSA-AES256-GCM-SHA384 ECDHE-ECDSA-AES256-GCM-SHA384 AES256-SHA256 DHE-DSS-AES256-SHA256 DHE-DSS-AES256-SHA DHE-DSS-AES128-SHA EDH-DSS-DES-CBC3-SHA !EXP !MEDIUM !LOW !eNULL !aNULL !RC4 !DES !MD5 !PSK !SRP
      -- SSL_hostname ===> hubble.krystal.co.uk
      -- SSL_server ===> 0
      -- SSL_use_cert ===> 0
      -- SSL_verify_mode ===> 0
      -- SSL_version ===> TLSv12
  _SSL_ctx ==> IO::Socket::SSL::SSL_Context=HASH(0x562475b19828)
      -- context ===> 94714584143456
      -- ocsp_cache ===> (undef)
      -- ocsp_mode ===> 0
      -- verify_mode ===> 0
  _SSL_fileno ==> 3
  _SSL_ioclass_upgraded ==> IO::Socket::INET
  _SSL_last_err ==> ARRAY(0x562475afdca0)
      [SSL wants a read first, 4]
  _SSL_object ==> 94714593482576
  _SSL_opened ==> 1
  io_socket_domain ==> 2
  io_socket_proto ==> 6
  io_socket_timeout ==> 120
  io_socket_type ==> 1
************************************************************
>>> USER +++++++
<<< 331 User <++++++> OK. Password required
>>> PASS *******
<<< 230 OK. Current restricted directory is /
<<+ 503 Unsupported command HELP.
>>> PWD
<<< 257 "/" is your current location
>>> FEAT
<<< 211-Extensions supported:
<<<  EPRT
<<<  IDLE
<<<  MDTM
<<<  SIZE
<<<  MFMT
<<<  REST STREAM
<<<  MLST type*;size*;sizd*;modify*;UNIX.mode*;UNIX.uid*;UNIX.gid*;unique*;
<<<  MLSD
<<<  AUTH TLS
<<<  PBSZ
<<<  PROT
<<<  UTF8
<<<  TVFS
<<<  ESTA
<<<  PASV
<<<  EPSV
<<<  SPSV
<<<  ESTP
<<< 211 End.
<<+ 111 Auto-adding OPTS Command!
>>> NOOP
<<< 200 Zzz...
<<+ 502 Unknown command MLSD.
<<+ 502 Unknown command NLST.
>>> OPTS UTF8 ON
<<< 200 OK, UTF-8 enabled
>>> TYPE I
<<< 200 TYPE is now 8-bit binary
>>> SYST
<<< 215 UNIX Type: L8
>>> PBSZ 0
<<< 200 PBSZ=0
>>> PROT P
<<< 200 Data protection level set to "private"
>>> PASV
<<< 227 Entering Passive Mode (77,72,1,20,213,32)
--- Host (77.72.1.20)  Port (54560)
>>> LIST
<<< 150 Accepted data connection
DEBUG: .../IO/Socket/SSL.pm:1620: start handshake
DEBUG: .../IO/Socket/SSL.pm:1177: global error: Undefined SSL object
DEBUG: .../IO/Socket/SSL.pm:787: ssl handshake not started
DEBUG: .../IO/Socket/SSL.pm:829: using SNI with hostname 77.72.1.20
DEBUG: .../IO/Socket/SSL.pm:894: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:897: done Net::SSLeay::connect -> 1
DEBUG: .../IO/Socket/SSL.pm:952: ssl handshake done
Unexpected EOF on Command Channel [0] (0, 1) ()
 at ./nickFTPTest.pl line 45.
DEBUG: .../IO/Socket/SSL.pm:3059: free ctx 94714584143456 open=94714584143456
DEBUG: .../IO/Socket/SSL.pm:3070: OK free ctx 94714584143456
perl ubuntu ftp ftp-client
1个回答
0
投票
© www.soinside.com 2019 - 2024. All rights reserved.