Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Checking file size with FTPClient

Posted on 1998-07-30
11
Medium Priority
?
230 Views
Last Modified: 2010-04-16
Hi Everybody,

I was wandering if there is a way of checking a file size using File Transfer Protocol prior to the file's download.
I am developing an application that handles very large files
(15 - 20M), and one of the requirements is not to download a file if it doesn't conform to a certain size requirements.
Please help.
Thank you in advance.
0
Comment
Question by:apetrovic
  • 6
  • 4
11 Comments
 
LVL 6

Expert Comment

by:gadio
ID: 1229243
When you are using the FTPClient (if you are using the one that is part of the java library) you can issue a ls command which returns a list of the files with sizes, similar to the unix ls -l command. Take the list and extract the file sizes.
0
 

Author Comment

by:apetrovic
ID: 1229244
Hi gadio,
Thanks for your answer.
I was thinking about the same solution, but resulted list would be dependent upon server's operating system, which is unacceptable in the specifications I have.
0
 
LVL 6

Expert Comment

by:gadio
ID: 1229245
Ok I agree. What you actually need to do is use the SIZE ftp command. This command returns to you the size of a given file. I assume that you are using the FTPClient in the java library. I'm afraid that this option is closed for you since the interface is protected. There are few options for you to take:
1. write the whole communication layer yourself and then you can issue the SIZE command to the ftp server.
2. Decompile the FTPClient so that you can insert your own commands (I did that this require a lot of work!).
3. Search the web for ftp clients implementations. www.gamelan.com would be a good place to start.

0
Independent Software Vendors: 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!

 

Author Comment

by:apetrovic
ID: 1229246
It seems that the first option you proposed is inevitable (I already searched Gamelan and a few other sites, without any success).
Thanks for your help gadio.
0
 
LVL 5

Expert Comment

by:msmolyak
ID: 1229247
If you leave me your e-mail address I will send you a Java FTP client I found on the Internet (do not remeber where) which looks quite reasonable. I has an FTP client implementation as well as the GUI client which you do not have to use.
0
 
LVL 6

Expert Comment

by:gadio
ID: 1229248
You are welcome. By the way, I can also email you the decompiled FTPClient and you can change it to work for you.
0
 

Author Comment

by:apetrovic
ID: 1229249
You can email me at apetrovic@imagictv.com
0
 
LVL 6

Expert Comment

by:gadio
ID: 1229250
Done.
If this solves your problem, tell me and I'll "answer" this question.
0
 
LVL 6

Accepted Solution

by:
gadio earned 400 total points
ID: 1229251
Hope that this solved your problem.
0
 

Author Comment

by:apetrovic
ID: 1229252
Hi gadio,

Sorry I did not reply sooner.

The SIZE command is not a part of the FTP standard, and is not supported by many FTP servers, so it can't be used as the ultimate solution. 

The best solution to the problem is to use FTP's LIST command, and extract the file size from the returned directory list (the solution you proposed at the begining).
It is true that the returned list would depend on FTP server's OS. However, vast majority of FTP servers returns directory listings whose layout complies to standard UNIX listing (the only exception is Win95). So, if you build your FTPClient knowing these facts, you can end up with relativly safe solution.
Or, you can ask your boss to change the specs, as I did.

Once again thanks for your help,

0
 
LVL 6

Expert Comment

by:gadio
ID: 1229253
You are welcome. Note however that there are still operations that are not supported by the default FTPClient. The most common operation that I needed thats not implemented is MKDIR. If you want to implement one of those - you will have no choice but to use the FTPClient source I sent you.
Good luck,
G.
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

Go is an acronym of golang, is a programming language developed Google in 2007. Go is a new language that is mostly in the C family, with significant input from Pascal/Modula/Oberon family. Hence Go arisen as low-level language with fast compilation…
Basic understanding on "OO- Object Orientation" is needed for designing a logical solution to solve a problem. Basic OOAD is a prerequisite for a coder to ensure that they follow the basic design of OO. This would help developers to understand the b…
Viewers will learn about basic arrays, how to declare them, and how to use them. Introduction and definition: Declare an array and cover the syntax of declaring them: Initialize every index in the created array: Example/Features of a basic arr…
Viewers will learn how to properly install Eclipse with the necessary JDK, and will take a look at an introductory Java program. Download Eclipse installation zip file: Extract files from zip file: Download and install JDK 8: Open Eclipse and …
Suggested Courses

824 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