?
Solved

ftpclient ascii transfer mode not the same as ascii ftp from unix box

Posted on 2004-04-23
13
Medium Priority
?
701 Views
Last Modified: 2012-05-04
I am trying to use the ftpClient class to ftp a file in ascii mode to a windows machine.
 But, the file size is different than when I use Hummingbird ftp or unix ftp.
 I guess, other ftp command creates an additional character at the end of each line (carriage return or line feed) for windows systems. I think that the ftpClient does not do that. The file created by ftpClient is smaller than the ones created by humming bird or unix ftp.

Here is my sample java code:
import java.io.*;
import java.util.*;
import sun.net.ftp.FtpClient;
import sun.net.TelnetInputStream;
public class FtpUpload {
  static String ftpaddress;
  static String ftpusername;
  static String ftppassword;
  static String ftpfilename;
  static String ftptransfermode;
  static String ftpremotefilename;
  static String ftpdirectory;
public static void main(String[] args) {
try {
   ftpaddress      = args[0];
   ftpusername      = args[1];
   ftppassword      = args[2];
   ftpfilename      = args[3];
   ftptransfermode = args[4];
   ftpremotefilename      = args[5];
   ftpdirectory      = args[6];
   System.out.println(ftpaddress);
   System.out.println(ftpusername);
   System.out.println(ftppassword);
   System.out.println(ftpfilename);
   System.out.println(ftptransfermode);
   System.out.println(ftpremotefilename);
   System.out.println(ftpdirectory);

    FtpClient ftpClient = new FtpClient();
    ftpClient.openServer(ftpaddress);
    ftpClient.login(ftpusername, ftppassword); // login
    if(ftptransfermode=="A")
      {
      ftpClient.ascii(); // change to ascii mode transfer
      }
    else  
     {
    ftpClient.binary(); // change to binary mode transfer           
     }
     
     if(ftpdirectory!="")
      {
       ftpClient.cd(ftpdirectory); // change directory
      }
 
    BufferedOutputStream out = new BufferedOutputStream(ftpClient.put(ftpfilename));
    BufferedInputStream in = new BufferedInputStream(new FileInputStream(ftpfilename));
    int b = -1;
    while ((b = in.read()) != -1) {
       out.write(b);
    }
    in.close();
    out.close();
    ftpClient.closeServer();
  } catch (Exception e) {
    e.printStackTrace();
    System.exit(1);
  }
}
}

Any suggestions??

Thanks
0
Comment
Question by:manishksinha-2004
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 2
  • 2
  • +1
13 Comments
 
LVL 86

Expert Comment

by:CEHJ
ID: 10903378
>>if(ftptransfermode=="A")

should strictly be

if ("A".equals(ftptransfermode))

Try that first
0
 
LVL 22

Expert Comment

by:NovaDenizen
ID: 10903868
Unix systems use a single character (ASCII CR) to signal an End of Line, and windows systems use two characters (ASCII CR and LF) in their convention.

FTP servers are supposed to perform this translation when moving files between dos and unix machines in text mode (mode "A"), either adding or removing the LF characters as is required.  If you instead use ftp's binary mode (mode "I") then the servers will keep their hands off the contents of the files, and not attempt to add or remove the LF characters.
0
 
LVL 92

Expert Comment

by:objects
ID: 10905155
yeah  sun.net.ftp.FtpClient is pretty basic, wouldn't rely on it.
Try a better ftp implementation.
0
Optimize your web performance

What's in the eBook?
- Full list of reasons for poor performance
- Ultimate measures to speed things up
- Primary web monitoring types
- KPIs you should be monitoring in order to increase your ROI

 
LVL 92

Expert Comment

by:objects
ID: 10905197
how do the file sizes compare with the originals?
0
 

Author Comment

by:manishksinha-2004
ID: 11155168
I am back again. Sorry for that. I have been trying out some perl scripts.

For my java test, I ftped a file from unix system to windows. The file on unix box contained 3 lines and had 45 bytes in it. Java ftp program created the same file with the same byte size, but hummingbird ftp program created the file on the windows box with a size of 48 bytes.
It seems to have added 3 bytes, 1 for each line (Line feed character).

Question is: How can I simulate this in java ftp program listed above.

Also, I wanted to know how to handle java ftp program when the remote server is not responding. Maybe, use threads... Sometime the java ftp program can hang if the remote server is not responding. I want to timeout after 5 minutes.

Thanks everyone
0
 
LVL 22

Accepted Solution

by:
NovaDenizen earned 252 total points
ID: 11155330
> Question is: How can I simulate this in java ftp program listed above.
Easy.  Just replace the CRs with CR/LF combinations.  As you are writing the file out, look for CR characters.  Instead of just writing out the CR, write out a CR/LF combination.

For the timeout part, I would put all the worker code that directly writes to and reads from the server into its own thread, waiting for requests from the rest of the program.  The rest of the program could poll it every couple of seconds to see if a response has come back.  Also create a watchdog thread that keeps track of how long it has been since the worker thread has done or received anything.  Every time the worker thread does or receives anything, it should reset the watchdog timer.  If the watchdog timer reaches 5 minutes without activity, it declares the worker timed out and acts to kill it and makes it clean up whatever resources it has allocated.

0
 
LVL 92

Expert Comment

by:objects
ID: 11156818
> How can I simulate this in java ftp program listed above.

Use BufferedReader to read file, and PrintWriter to save file to disk.
0
 

Author Comment

by:manishksinha-2004
ID: 11165451
Do you have a test code for the threads?
 I guess the CR/LF is only for windows system, and not for unix. How can one find out what system is the file being written to?
0
 
LVL 92

Assisted Solution

by:objects
objects earned 248 total points
ID: 11166762
BufferedReader/PrintWriter should lhopefully ook after that for you.
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

INTRODUCTION Working with files is a moderately common task in Java.  For most projects hard coding the file names, using parameters in configuration files, or using command-line arguments is sufficient.   However, when your application has vi…
Java Flight Recorder and Java Mission Control together create a complete tool chain to continuously collect low level and detailed runtime information enabling after-the-fact incident analysis. Java Flight Recorder is a profiling and event collectio…
Viewers learn about the “for” loop and how it works in Java. By comparing it to the while loop learned before, viewers can make the transition easily. You will learn about the formatting of the for loop as we write a program that prints even numbers…
Viewers will learn about arithmetic and Boolean expressions in Java and the logical operators used to create Boolean expressions. We will cover the symbols used for arithmetic expressions and define each logical operator and how to use them in Boole…
Suggested Courses
Course of the Month14 days, 16 hours left to enroll

771 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question