BookmarkSubscribeRSS Feed
DarrylLawrence
Obsidian | Level 7

Hi

 

I am trying to send a file to a customer via FTP - using 2 methods but both return errors. Please help!

 

Method 1:

filename infile '/sas/lsf/Cred/Test_File.xls';

filename outdir ftp '/Data_Test' DIR FILEEXT
host="199.22.128.58"
user="tfgftp"
pass="abc123"
port=22;
/**********************************************************************/
data _null_;
infile infile truncover;
input;
file outdir(Test_File.xls);
put _infile_;
run;

 

Log:

NOTE: The infile INFILE is:
Filename=/sas/lsf/Cred/Test_File.xls,
Owner Name=darrylla,Group Name=sas,
Access Permission=-rw-rw-r--,
Last Modified=02Jun2016:13:40:05,
File Size (bytes)=66048

NOTE: SSH-2.0-CoreFTP-0.3.3
ERROR: Invalid reply received from FTP server..
NOTE: 0 records were read from the infile INFILE.
NOTE: The SAS System stopped processing this step because of errors.
NOTE: DATA statement used (Total process time):
real time 1:03.37
cpu time 0.01 seconds

 

How do I resolve this error?  I can login to the FTP site using FileZilla (ftp client software) so the user login details are valid.

 

Method 2:

Generating a sftp.cmd file.

 

curl -v -k --ftp-ssl-ccc -T /sas/lsf/Cred/Test_File.xls ftp://tfgftp:abc123@199.22.128.58:22/Data_Test 2>&1 | tee /sas/lsf/Cred/Logs/sftp.log

 

Log

NOTE: The infile DO_SFTP is:
Pipe command="/sas/lsf/Credico/Logs/sftp.cmd"

NOTE: 8 records were read from the infile DO_SFTP.
The minimum record length was 22.
The maximum record length was 5002.
NOTE: DATA statement used (Total process time):
real time 1:03.40
cpu time 0.02 seconds

 

sftp logfile

* Trying 199.22.128.58...
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed

0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0* Connected to 199.22.128.58(199.22.128.58) port 22 (#0)
< SSH-2.0-CoreFTP-0.3.3

0 0 0 0 0 0 0 0 --:--:-- 0:00:01 --:--:-- 0
0 0 0 0 0 0 0 0 --:--:-- 0:00:02 --:--:-- 0

 

writes out multiple lines untill the connection is closed.

 

 0 0 0 0 0 0 0 0 --:--:-- 0:01:01 --:--:-- 0
0 0 0 0 0 0 0 0 --:--:-- 0:01:02 --:--:-- 0
0 0 0 0 0 0 0 0 --:--:-- 0:01:03 --:--:-- 0* response reading failed
* Closing connection 0
curl: (56) response reading failed

3 REPLIES 3
Kurt_Bremser
Super User

CoreFTP is Windows-only, so it seems your target system is Windows. You will need to use correct file syntax for this.

But the kicker is that you specified port 22 (SSH) in a filename ftp. Omit specifying a port number so that SAS will use the correct port for FTP (21).

 

 

DarrylLawrence
Obsidian | Level 7

Thanks for the info Kurt.

 

I have used the first option before for another project and it worked. ie copying a file from a Unix location to a FTP site.  The client has setup their ftp connection on port 22......

 

You mentioned CoreFTP. Do you have file syntax for this?

Kurt_Bremser
Super User

Regarding file syntax: since you have to deal with a Windows system, use C:\...\...\... instead of /.../.../...

Unless CoreFTP is set up so that it can translate UNIX-style paths to something sensible within the Windows filesystem.

 

But I still state that port 22 is reserved for the Secure Shell protocol, and the FTP Access Method simply won't work.

If someone else actually set up a standard (unencrypted, non-secure!) FTP server to run on port 22 (probably to trick their way around firewalls that only allow secure connections), their Information Security Officer should have a most severe talk with them 😞

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 3 replies
  • 5044 views
  • 0 likes
  • 2 in conversation