What is FTP? How does it work?
Copright (c) 1995, 1996, by Ian Mapleson
Last Revision: 01/07/96
(NB#1: all example commands and ftp program output have been indented by two
spaces in order to deliniate this data from the surrounding text)
(NB#2: if you are already familiar with using ftp to download files, but want
to know how to _upload_ files, then goto Part 2)
(NB#3: This file is normally sent to readers of the rec.games.computer.doom.*
newsgroups and therefore contains some information specific to Doom. My
apologies if these specifics are of no relevance to you :)
---------------< Part 1 >---------------
Introduction & how to download files from an ftp site
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
'ftp' stands for File Transfer Protocol. It is the means by which one may
transfer files to and from remote 'sites' around the world.
An 'ftp site' is any computer system in the world that is accessible on the
Internet and has an ftp server set up for it which people can access.
Ftp sites contain vast amounts of data on EVERY subject imaginable. There are
hundreds of thousands of sites worldwide. Some of them contain files for Doom
related stuff. :)
There is a single central site for Doom information, based in the USA, called:
ftp.cdrom.com
Other sites around the world 'mirror' ftp.cdrom.com. This means that, every
night (sometimes less often), they update their files so that they contain
exactly the same files as ftp.cdrom.com in their Doom directory. Thus, if
someone far away has slow access to ftp.cdrom.com, they can use a mirror site
instead which will have better data transfer rates.
Every site has a name, but the name is really just an alias for a code number,
called an IP (Internet Protocol) address. Some ftp programs are not able to
translate the names to numbers and so one needs the actual IP addresses.
What I would say next depends on what kind of ftp program you're using. Some
are command line based, like the ftp command in Unix systems. Others are
graphical and might run under something like Windows. People using WWW browsers
(Netscape, Mosaic, etc.) also have ftp access by using the prefix 'ftp://'
instead of 'http://'. So, here is some general info and examples.
The vast majority of sites world wide are not freely accessible, ie. the only
people who can access them are people who have user accounts at that site. Many
Universities are like this - they often have separate machines setup as
anonymous ftp sites.
But there are also a LARGE number of sites (probably around 300000+) for which
ANYONE can login to them and retrieve (and in many cases send) files. These
are called 'anonymous' ftp sites because it doesn't matter who or where you
are, you can use them.
To access an anonymous ftp site, one ftp's (pronounced 'Eff Tee Peez') to the
appropriate site, perhaps via a command like:
ftp flinux.tu-graz.ac.at
and then, assuming the machine is successful in accessing the site, one is
presented with a login page. Note that for WWW browsers, the equivalent URL
would be:
ftp://flinux.tu-graz.ac.at/
Here is the login page that I get for this site, which is based in Austria,
Europe (the machine I am using is called 'nikita', by the way):
nikita% ftp flinux.tu-graz.ac.at
Connected to flinux.tu-graz.ac.at.
220 flinux FTP server (Linux flinux 1.1.67 #1 Tue Nov 29 12:50:51 GMT-0100 1994 i386) ready.
Name (flinux.tu-graz.ac.at:mapleson):
Most sites will have something like this when you access them. Now, since one
wants to login as an anonymous user, one enters the word 'anonymous' as one's
name (note that this is not necessary when accessing an ftp site using a web
browser because the browser takes care of the login process automatically). On
this site, you get the following:
Name (flinux.tu-graz.ac.at:mapleson): anonymous
331 Guest login ok, send e-mail address as password.
Password:
At this stage, the site wants you to enter your full email address as a
password. This enables the site manager to assess the load that is being put on
their server and so ease administration.
So, I enter:
mapleson@cee.hw.ac.uk
You would enter your appropriate email address instead. Note that when entering
your email address the ftp host will not echo what you type, so type carefully.
When I enter my address, it says:
230-
230- All transfers are logged with your host name and email address.
230- If you don't like this policy, disconnect now!
230-
230-Welcome, archive user from nikita.cee.hw.ac.uk.
230-This is an experimental FTP server. If have any unusual problems,
230-please report them via e-mail to ftpadmin@flinux.tu-graz.ac.at .
230-If you do have problems, please try using a dash (-) as the first character
230-of your password -- this will turn off the continuation messages that may
230-be confusing your ftp client.
230-
230-Local Time is Tue Dec 6 19:23:35 1994.
230-
230-You are user 3 out of a maximum 20.
230-
230-
230-----------------------------------------------------------------------
230-
230-README ... some information to this archive
230-incoming ... if you want to upload -> do it in this directory
230-pub ... the archive ...
230-
230-
230 Guest login ok, access restrictions apply.
ftp>
This is a typical 'welcome' page for an ftp site.
What the site actually is is just one big directory structure of files that one
may browse through using the usual 'cd' and 'dir' commands. When you see a file
you want, you can get it using the 'get' command. You can see the details of
just one particular file, or group of files, by being more specific with the
'dir' command, eg. entering 'dir filename.zip' will display the directory
information for just that file. This is an easy way to see if a particular file
is actually present in a directory without having to list the entire directory
(of course, this relies on you knowing the exact spelling of the file name.
Usually, the presence of capital letters in a file name _does_ make a
difference).
Transferring a file _from_ the ftp site _to_ your site is called 'downloading',
whilst sending a file from your site to the ftp site is called 'uploading'.
Some directories on ftp sites are not accessible as these may be administrative
directories which anonymous users should have no interest in.
Most sites have a 'pub' (ie. public) directory and this is where the files of
interest to anyone usually are. However, this is not always the case.
Most sites have some kind of 'README' file which explains where everything is.
There is often a complete recursive file listing of the ftp site, sometimes
called 'FILELIST', but often called 'ls-lR' or something similar. You can
download this to see a complete list of _everything_ on the ftp site, but beware
as this file is often very large!
Most files are not just plain ASCII text; such files may be image files (like
GIF or JPG, etc) or executable programs, tar files, zip files, or a whole
variety of compression formats used to save space. These have to be downloaded
in 'binary' mode, so one enters 'bin' or perhaps 'image' to switch to binary
mode.
(quick info: ASCII characters, stored as one byte (ie. 8 bits) for one
character, only use 7 of the 8 available bits. In a binary file, all 8 bits of
each byte are used, eg. an executable program. Hence, in order to download or
upload binary files, you have to tell the ftp program that you want to deal
with binary, and not ASCII, data, otherwise it'll "miss out" the 8th bit in
each byte and your downloaded file will be useless).
In general, it is always safer to download _any_ file in binary mode, just in
case the ftp site's idea of ASCII isn't _your_ site's idea of what ASCII is
supposed to be. :D
It is also useful, when downloading files, to enter 'hash' as this lets you see
how fast the transfer is going. What happens is that '#' symbols get displayed
as the data is transfered, denoting (for example) 8K of data per hash mark. On
some programs, like ncftp, this isn't necessary, as a percentage number is
constantly shown. On programs like ftp for Windows, it should display the
number of bytes downloaded compared to the actual file size, thus showing you
how the transfer is progressing. Web browsers will have a similar display. On
Unix systems, perhaps in another XWindow, one can see how the transfer is going
by repeatedly entering 'ls -l' in the directory to which the ftp site is
sending the file. Watching for a few seconds will show how fast the data is
arriving and, hence, how long the transfer is likely to take. Note that
transfer speed can vary considerably during any transfer, one minute going fast
and the next slow; hence, if nothing is happeneing, don't get impatient - wait
a while and you'll probably see the data being transmitted again.
Anyway, on the example site I'm using here, to get to the place on the ftp site
where the Doom files are, one enters:
cd pub/doom
When you do this, you get the following (of course, if you ever try this site,
the exact contents will probably have changed slightly since I did this example
session):
250-Welcome to the greatest DOOM ftp server in the world!
250-
250-NEWSTUFF - The NEWEST files are here. Incoming is write only now.
250-HELP - Get the FTP faq and other help/support information
250-text/faq - Doom FAQ and others.
250-wads - User build WAD files for Registered DOOM only.
250-sounds - Replacement sounds for DOOM.
250-wad_edit - WAD file editors for Registered DOOM only.
250-misc - Anything else that just doesn't fit into these boxes.
250-graphics - Neato-nifty graphics patches for DOOM
250-id - Here is the shareware version of DOOM and upgrades
250-deu - Official USA site for DEU, greatest DOOM editor.
250-lmps - Recorded games of people with no lives....
250-incoming - Put your new files here. I move them around.
250-doom2 - Files for the Doom ][ software.
250-
250-
250-Send all suggestions to barry@noc.unt.edu
250-
250-THIS FILE MODIFIED 9.24.94
250-
250 CWD command successful.
Since this directory is a 'mirror' of the pub/doom directory on the
ftp.cdrom.com site, the above text is _exactly_ what you'd see if you ftp'd to
ftp.cdrom.com instead of the example site I'm using here.
Anyway, suppose I wanted to get an add-on level for Doom. Here is an example
session:
ftp> cd wads
250-Welcome to the wads section:
250-
250-send all suggestions to barry@noc.unt.edu
250-
250-9-7-94
250-
250-/newwads is now the place to find the newest wads. I'll update this
250-note everytime I move stuff. Also, check the ls-LR for this directory
250-to get a complete list of just the wads. Remember to check the /newwads2
250-directory also. Newwads2 contains all of Augusts submissions. Newwads
250-will have all of Septembers.
250-
250-
250-
250 CWD command successful.
ftp> dir
200 PORT command successful.
150 Opening ASCII mode data connection for /bin/ls.
total 139
-r--r--r-- 1 root ftp 398 Sep 10 10:48 .message
drwxr-xr-x 2 root ftp 1024 Dec 3 06:29 1-9
-r--r--r-- 1 root ftp 1052 Jul 1 16:27 HOW_TO_USE_WADS
-r--r--r-- 1 root ftp 227 Jul 13 10:23 README
drwxr-xr-x 2 root ftp 5120 Dec 3 06:27 a-c
drwxr-xr-x 2 root ftp 1024 Sep 25 04:42 combos
drwxr-xr-x 2 root ftp 5120 Dec 3 06:54 d-f
drwxr-xr-x 2 root ftp 6144 Dec 3 06:15 deathmatch
-r--r--r-- 1 root ftp 32875 Aug 15 23:14 dmrk0815.txt
drwxr-xr-x 2 root ftp 3072 Dec 3 07:01 g-i
drwxr-xr-x 2 root ftp 2048 Dec 3 07:00 j-l
-r--r--r-- 1 root ftp 19202 Dec 2 12:16 ls-LR
drwxr-xr-x 2 root ftp 3072 Dec 3 06:59 m-o
drwxr-xr-x 2 root ftp 5120 Dec 3 07:33 newwads
drwxr-xr-x 2 root ftp 3072 Dec 3 07:33 newwads2
drwxr-xr-x 2 root ftp 3072 Dec 3 06:57 p-r
drwxr-xr-x 2 root ftp 1024 Dec 3 07:01 reviews
drwxr-xr-x 2 root ftp 6144 Dec 3 06:47 s-u
drwxr-xr-x 2 root ftp 1024 Dec 3 06:15 utility
drwxr-xr-x 2 root ftp 2048 Dec 4 05:26 v-z
-r--r--r-- 1 root ftp 33567 Jul 24 11:07 wads0724.rev
226 Transfer complete.
1338 bytes received in 1 seconds (1.3 Kbytes/s)
ftp> cd newwads
250 CWD command successful.
ftp> dir
200 PORT command successful.
150 Opening ASCII mode data connection for /bin/ls.
total 8682
-r--r--r-- 1 root ftp 6919 Oct 3 11:49 invade2.txt
-r--r--r-- 1 root ftp 655718 Oct 4 07:36 invade2.zip
-r--r--r-- 1 root ftp 1439 Oct 4 13:34 invepi2.txt
-r--r--r-- 1 root ftp 1919191 Oct 4 13:37 invepi2.zip
-r--r--r-- 1 root ftp 1439 Oct 4 13:04 invpro2.txt
-r--r--r-- 1 root ftp 3119184 Oct 4 13:08 invpro2.zip
-r--r--r-- 1 root ftp 752 Oct 22 23:40 quest12.txt
-r--r--r-- 1 root ftp 182 Oct 23 01:07 quest12.zip
-r--r--r-- 1 root ftp 3360 Sep 29 10:55 reactor3.txt
-r--r--r-- 1 root ftp 21809 Sep 29 10:54 reactor3.zip
-r--r--r-- 1 root ftp 2340 Nov 11 03:57 red.txt
-r--r--r-- 1 root ftp 77252 Nov 11 03:58 red.zip
-r--r--r-- 1 root ftp 2062 Oct 30 06:19 redroom.txt
-r--r--r-- 1 root ftp 25277 Oct 30 06:19 redroom.zip
-r--r--r-- 1 root ftp 2040 Oct 5 04:59 rot_e2m1.txt
-r--r--r-- 1 root ftp 131886 Oct 5 05:11 rot_e2m1.zip
-r--r--r-- 1 root ftp 4187 Nov 10 02:44 rrward02.txt
-r--r--r-- 1 root ftp 225575 Nov 10 02:44 rrward02.zip
-r--r--r-- 1 root ftp 2393 Oct 18 08:59 run666.txt
-r--r--r-- 1 root ftp 67346 Oct 18 08:59 run666.zip
-r--r--r-- 1 root ftp 3178 Oct 18 08:59 ry11ecr.txt
-r--r--r-- 1 root ftp 68460 Oct 18 08:59 ry11ecr.zip
-r--r--r-- 1 root ftp 349 Oct 25 00:27 sawtime.txt
-r--r--r-- 1 root ftp 204243 Oct 25 00:35 sawtime.zip
-r--r--r-- 1 root ftp 12408 Oct 30 22:48 serenity.txt
-r--r--r-- 1 root ftp 405543 Oct 30 22:48 serenity.zip
-r--r--r-- 1 root ftp 3223 Oct 4 21:22 sersound.txt
-r--r--r-- 1 root ftp 801471 Oct 4 21:22 sersound.zip
-r--r--r-- 1 root ftp 1554 Oct 23 18:28 sherhell.txt
-r--r--r-- 1 root ftp 135457 Oct 23 18:23 sherhell.zip
-r--r--r-- 1 root ftp 5547 Oct 24 16:38 shoots.txt
-r--r--r-- 1 root ftp 152230 Oct 24 16:38 shoots.zip
-r--r--r-- 1 root ftp 2034 Oct 15 04:36 statx2.txt
-r--r--r-- 1 root ftp 50226 Oct 15 04:38 statx2.zip
-r--r--r-- 1 root ftp 1612 Oct 14 21:14 straw.txt
-r--r--r-- 1 root ftp 62731 Oct 14 21:14 straw.zip
-r--r--r-- 1 root ftp 60513 Oct 28 06:50 straw2.zip
-r--r--r-- 1 root ftp 60804 Oct 28 07:09 straw3.zip
-r--r--r-- 1 root ftp 16 Oct 28 07:26 straw4.zip
-r--r--r-- 1 root ftp 16 Oct 29 06:08 straw6.zip
-r--r--r-- 1 root ftp 1853 Nov 16 02:03 switches.txt
-r--r--r-- 1 root ftp 38501 Nov 16 02:03 switches.zip
-r--r--r-- 1 root ftp 2793 Nov 16 22:29 tmatch-1.txt
-r--r--r-- 1 root ftp 16581 Nov 16 22:29 tmatch-1.zip
-r--r--r-- 1 root ftp 3335 Oct 13 09:56 tripwire.txt
-r--r--r-- 1 root ftp 34080 Oct 13 09:56 tripwire.zip
-r--r--r-- 1 root ftp 4140 Oct 28 21:55 uac-hq.txt
-r--r--r-- 1 root ftp 159356 Oct 28 22:10 uac-hq.zip
-r--r--r-- 1 root ftp 1134 Nov 12 21:14 walzhaus.txt
-r--r--r-- 1 root ftp 111546 Nov 12 21:14 walzhaus.zip
-r--r--r-- 1 root ftp 95 Nov 17 21:21 wetwrkd1.txt
-r--r--r-- 1 root ftp 65892 Nov 17 21:19 wetwrkd1.zip
-r--r--r-- 1 root ftp 2187 Nov 10 20:50 xmas.txt
-r--r--r-- 1 root ftp 55828 Nov 10 20:50 xmas.zip
226 Transfer complete.
3676 bytes received in 4.7 seconds (0.76 Kbytes/s)
ftp> bin
200 Type set to I.
ftp> hash
Hash mark printing on (8192 bytes/hash mark).
ftp> get wetwrkd1.zip
200 PORT command successful.
150 Opening BINARY mode data connection for wetwrkd1.zip (65892 bytes).
##########################################################################
###################################
226 Transfer complete.
local: wetwrkd1.zip remote: wetwrkd1.zip
65892 bytes received in 34 seconds (1.9 Kbytes/s)
ftp> close
221 Goodbye.
ftp> quit
nikita%
So, that's how one gets a file via ftp.
Incidentally, I downloaded the *same* file from a different Doom mirror site in
Europe (Sweden instead of Austria) and I got this:
ftp> get wetwrkd1.zip
200 PORT command successful.
150 Opening BINARY mode data connection for wetwrkd1.zip (65892 bytes).
##########################################################################
###################################
226 Transfer complete.
local: wetwrkd1.zip remote: wetwrkd1.zip
65892 bytes received in 10 seconds (6.2 Kbytes/s)
As you can see, the speed of ftp sites varies greatly. ftp.luth.se can
transfer as fast as 100K/second, while some sites I've tried to use are so
slow (less than 100 bytes/second) that I just stop the ftp and try somewhere
else. The load on a site varies greatly and it is best to access a site
when the local time of the country the site is based in is in the early
hours of the morning (i.e. people in the U.K. should access USA sites around
10am U.K. time because that is when most folk in the USA are asleep. 10am
GMT would be anything from 2am to 5am US time, depending on time zone. Mind
you, weekends are pretty quiet as well).
Anyway, here are a couple of other things about using anonymous ftp:
- Most sites will let you enter 'ftp' instead of 'anonymous' as your login name,
which saves typing errors.
- Most sites will let you abbreviate your email address to just your name
followed by the '@' symbol (so I would enter 'mapleson@' for instance, minus
the quotes of course). In fact, nowadays, I just enter 'm@' as a password,
which seems to work just fine.
- Most sites don't care if you don't bother entering 'close' before
entering 'quit'. I never enter 'close' and I've not had any problems yet.
You can also enter 'bye' which seems to be identical to 'quit', probably for
the sake of backwards compatability.
- It is always best to use binary mode for transfering *anything*, even if
the file is just ASCII text. It's more reliable as one can never be quite
sure what the ftp site's idea of an ASCII file is! :D
---------------< Part 2 >---------------
How to upload (ie. send) files to an ftp site.
Note for Doom PWAD writers: there is a standardised 'PWAD Template' form which
you can upload as a .txt file to accompany your zipped PWAD. The template file
can be downloaded as a zip file from ftp.cdrom.com or any of its mirror sites.
The directory on ftp.cdrom.com is:
pub/doom/docs/editing
and the file is:
wadtempt.zip
There is an accompanying text file called:
wadtempt.txt
- End of note for PWAD authors.
Uploading files.
^^^^^^^^^^^^^^^^
This process is no more complicated than receiving files. The first thing to do
is to make sure you are in the right directory when running the ftp program, ie.
the directory on your computer that contains the file(s) you want to upload. For
Windows ftp programs, this probably just means using the file browser, etc.
(NB: you can't upload files to an ftp site with a web browser).
Next you ftp to the intended site just as before, using 'ftp' or 'anonymous' as
a login name, email address as password, etc. (or the equivalent set of actions
necessary for your ftp program).
On most sites, depending on what you're wanting to upload, there will be a
specific directory on the site where uploads are supposed to be placed.
Usually, this directory will be called 'incoming'.
In the case of Doom files, because the Doom sites operate a mirror system,
uploaded Doom files should _only_ be sent to the appropriate incoming directory
on the main Doom site, ftp.cdrom.com (this is because anything that is uploaded
to a mirror's 'incoming' directory will just be deleted when the system
compares the mirror directory to the main directory at ftp.cdrom.com).
Try and make sure you find the right directory into which you intend to
upload your file(s).
Now enter 'bin' and 'hash' as usual (minus the quotes). There are two
commands to upload files, 'send' and 'put'. As far as I can tell, there is
no difference between them. On Windows ftp programs this is irrelevant of
course as one would just click on a button to send the file.
Anyway, as an example, one might enter something like:
send myfile.zip
As before, the file will transfer at whatever speed, and hash marks (if using a
command style ftp program) will appear as the transfer progresses.
For uploading files, the MOST important thing is to ALWAYS upload in _binary_
mode. Many people get justifiably annoyed when they download a large file (a
Doom PWAD add-on level, for instance) and find that it is useless because the
author of the file forgot to upload the file in binary mode. So, remember this
as it's very important.
It is accepted practice, and a sensible practice at that, to always upload a
descriptive text file to accompany whatever the main file was that was
uploaded. Such a file should explain what the main file actually is, who wrote
it, how to use it, where to send bug reports, etc. Such 'README' type files
usually end in '.txt'. So, if I uploaded a Doom add-on level called
'diehard.zip', then I should upload a file called 'diehard.txt' which explains
what the 'diehard.zip' file actually is. As I said before, there is a 'standard'
.txt template file available to help PWAD authors with this. See the beginning
of part 2 for details.
Of course, if the main file you're actually sending is purely text, then an
accompanying .txt file probably isn't necessary (unless the main file is quite
large. An example is the Doom FAQ - that has a .txt file).
After sending files, one exits ftp in the usual manner via 'quit' or 'close',
etc.
Final notes:
^^^^^^^^^^^^
There are some other quite useful commands to bare in mind when using ftp.
Some may or may not be relevant to Windows style ftp programs (they certainly
arnen't relevant to web browsers, since they will have a graphical-interface
way of doing the equivalent operation).
The first is the 'lcd' command, which allows you to change the current
directory on _your_ site, without exiting the ftp program. Useful if you find
you've started the ftp session in the wrong directory. So, for instance, you
might enter:
lcd ..
A message will appear telling you your new directory path. This will not affect
whatever directory it is that you are currently 'in' on the ftp site.
Another useful command is one which allows you to view a _text_ file only
from within the ftp program (this applies to command line based ftp
programs only). You'd enter something like:
recv filename.txt |more
This will get the text file and pipe it through the 'more' program, thus
displaying the file on your screen in the usual more-style manner ('press
space to continue' messages appearing, etc. Press CTRL-C to quite the
'more' listing in the usual manner). Note that there must _not_ be a
space between the pipe '|' symbol and the word 'more'.
When you use recv in the above manner, the file does _not_ get saved to
your directory. It's just a way of seeing the contents of a file on a site
without committing yourself to actually downloading it (ie. if the file turns
out to be one you'd like, then you can press 'Q' which will quit the 'more'
listing process).
Multiple files.
^^^^^^^^^^^^^^^
It is possible to send and receive more than one file at once when using ftp.
Thus, for instance, suppose a directory on a NASA site contained loads of
astronomy images of the comet impact on Jupiter. The image files might be named
thusly:
impact00.jpg
impact01.jpg
impact02.jpg
impact03.jpg
impact04.jpg
.
.
.
and so on. It would be rather laborious to enter 'get ' for each
individual file, especially if there several hundred such files. :D
So, instead, you can enter a single command to get all of them. The command for
this is 'mget'. This will allow you to get more than one file at a time via the
use of 'wildcards'. Hence, to download ALL the pictures in one go, you would
enter:
mget impact*.jpg
or just:
mget impact*.*
Try to be as specific as possible when using wildcards like this, to ensure
that you don't download files which you don't want.
Note that, depending on the default settings of your ftp program, you may
or may not get 'prompted' for each file with a message that says something
like:
Retrieve file 'impact00.jpg'? (Y/N) :
^
Again, it's a pain to have to enter 'Y' dozens of times, so if you're sure you
want them all, you can use the 'prompt' command before you enter the 'mget'
command. This will toggle whether or not you are prompted for confirmation
during mget operations. To see whether multiple-file-prompting is currently on
or off, enter:
status
This will display various items of information about the current status
of the ftp session. For instance (just running the ftp program without
connecting anywhere):
nikita% ftp
ftp> status
Not connected.
No proxy connection.
Mode: stream; Type: ascii; Form: non-print; Structure: file
Verbose: on; Bell: off; Prompting: off; Globbing: on
Store unique: off; Receive unique: off
Case: off; CR stripping: on
Ntrans: off
Nmap: off
Hash mark printing: off; Use of PORT cmds: on
ftp> quit
The prompting status is shown as he 3rd item on the 4th line of status
information in this case.
There are a number of other ftp commands, most of which you'll probably
never use, or rarely anyway. Some are just shortcuts, for instance you
can enter:
cdup
instead of:
cd ..
A complete list of commands can be seen by entering 'help'. eg.
ftp> help
Commands may be abbreviated. Commands are:
! cr macdef proxy send
$ delete mdelete sendport status
account debug mdir put struct
append dir mget pwd sunique
ascii disconnect mkdir quit tenex
bell form mls quote trace
binary get mode recv type
bye glob mput remotehelp user
case hash nmap rename verbose
cd help ntrans reset ?
cdup lcd open rmdir
close ls prompt runique
You can find out what a command is by entering:
help
eg.
ftp> help ntrans
ntrans set translation table for default file name mapping
What the hell _that_ means I have no idea! :D But anyway... :) Actually, you
can read about this command in the man page given at the end of this help
file. It may be useful for Unix users who are ftp'ing to a non-Unix site. I
haven't had reason to use it yet, but you never know.
The information you receive when using the 'help' command in the above manner
tends to be very brief, for example:
ftp> help mget
mget get multiple files
Not much info there. :\ This is the main reason that I have written this help
file. I hope you'll find it useful.
And that's it, I guess. If you're using Unix, there should be a manual page
about ftp, which I have included below, so I will leave you with that. It has
much more information on the various commands than the on-line help within
ftp program has, so it is well worth a read, even if you're not using a Unix
system. It also lists all the various initial command line options.
If you have any further questions on ftp, please post to:
rec.games.computer.doom.help
or email me and I will attempt to answer them.
All comments and suggestions on further additions to this file are most welcome.
************************ UNIX Manual Page For 'ftp'.... ************************
NAME
ftp - file transfer program
SYNOPSIS
ftp [ -dgintv ] [ hostname ]
AVAILABILITY
This command is available with the Networking software
installation option. Refer to Installing SunOS 4.1 for
information on how to install optional software.
DESCRIPTION
ftp is the user interface to the ARPANET standard File
Transfer Protocol (FTP). ftp transfers files to and from a
remote network site.
The client host with which ftp is to communicate may be
specified on the command line. If this is done, ftp immedi-
ately attempts to establish a connection to an FTP server on
that host; otherwise, ftp enters its command interpreter and
awaits instructions from the user. When ftp is awaiting
commands from the user, it displays the prompt `ftp>'.
OPTIONS
Options may be specified at the command line, or to the com-
mand interpreter.
-d Enable debugging.
-g Disable filename "globbing."
-i Turn off interactive prompting during multiple file
transfers.
-n Do not attempt "auto-login" upon initial connection.
If auto-login is enabled, ftp checks the .netrc file in
the user's home directory for an entry describing an
account on the remote machine. If no entry exists, ftp
will prompt for the login name of the account on the
remote machine (the default is the login name on the
local machine), and, if necessary, prompts for a pass-
word and an account with which to login.
-t Enable packet tracing (unimplemented).
-v Show all responses from the remote server, as well as
report on data transfer statistics. This is turned on
by default if ftp is running interactively with its
input coming from the user's terminal.
! [ command ]
Run command as a shell command on the local machine.
If no command is given, invoke an interactive shell.
$ macro-name [ args ]
Execute the macro macro-name that was defined with the
macdef command. Arguments are passed to the macro
unglobbed.
account [ passwd ]
Supply a supplemental password required by a remote
system for access to resources once a login has been
successfully completed. If no argument is included,
the user will be prompted for an account password in a
non-echoing input mode.
append local-file [ remote-file ]
Append a local file to a file on the remote machine.
If remote-file is left unspecified, the local file name
is used in naming the remote file after being altered
by any ntrans or nmap setting. File transfer uses the
current settings for "representation type", "file
structure", and "transfer mode".
ascii
Set the "representation type" to "network " ASCII".
This is the default type.
bell Sound a bell after each file transfer command is com-
pleted.
binary
Set the "representation type" to "image".
bye Terminate the FTP session with the remote server and
exit ftp. An EOF will also terminate the session and
exit.
case Toggle remote computer file name case mapping during
mget commands. When case is on (default is off),
remote computer file names with all letters in upper
case are written in the local directory with the
letters mapped to lower case.
cd remote-directory
Change the working directory on the remote machine to
remote-directory.
cdup Change the remote machine working directory to the
parent of the current remote machine working directory.
close
Terminate the FTP session with the remote server, and
return to the command interpreter. Any defined macros
are erased.
cr Toggle RETURN stripping during "network " ASCII" type
file retrieval. Records are denoted by a
RETURN/LINEFEED sequence during "network " ASCII" type
file transfer. When cr is on (the default), RETURN
characters are stripped from this sequence to conform
with the UNIX system single LINEFEED record delimiter.
Records on non-UNIX-system remote hosts may contain
single LINEFEED characters; when an "network " ASCII"
type transfer is made, these LINEFEED characters may be
distinguished from a record delimiter only when cr is
off.
delete remote-file
Delete the file remote-file on the remote machine.
debug [ debug-value ]
Toggle debugging mode. If an optional debug-value is
specified it is used to set the debugging level. When
debugging is on, ftp prints each command sent to the
remote machine, preceded by the string `-->'.
dir [ remote-directory ] [ local-file ]
Print a listing of the directory contents in the direc-
tory, remote-directory, and, optionally, placing the
output in local-file. If no directory is specified,
the current working directory on the remote machine is
used. If no local file is specified, or local-file is
`-', output is sent to the terminal.
disconnect
A synonym for close.
form [ format-name ]
Set the carriage control format subtype of the
"representation type" to format-name. The only valid
format-name is non-print, which corresponds to the
default "non-print" subtype.
get remote-file [ local-file ]
Retrieve the remote-file and store it on the local
machine. If the local file name is not specified, it
is given the same name it has on the remote machine,
subject to alteration by the current case, ntrans, and
nmap settings. The current settings for "representa-
tion type", "file structure", and "transfer mode" are
used while transferring the file.
glob Toggle filename expansion, or "globbing", for mdelete,
mget and mput. If globbing is turned off, filenames
are taken literally.
Globbing for mput is done as in csh(1). For mdelete
and mget, each remote file name is expanded separately
on the remote machine, and the lists are not merged.
Expansion of a directory name is likely to be radically
different from expansion of the name of an ordinary
file: the exact result depends on the remote operating
system and FTP server, and can be previewed by doing
`mls remote-files -'.
mget and mput are not meant to transfer entire direc-
tory subtrees of files. You can do this by transfer-
ring a tar(1) archive of the subtree (using a
"representation type" of "image" as set by the binary
command).
hash Toggle hash-sign (#) printing for each data block
transferred.
help [ command ]
Print an informative message about the meaning of com-
mand. If no argument is given, ftp prints a list of
the known commands.
lcd [ directory ]
Change the working directory on the local machine. If
no directory is specified, the user's home directory is
used.
ls [ remote-directory ] [ local-file ]
Print an abbreviated listing of the contents of a
directory on the remote machine. If remote-directory
is left unspecified, the current working directory is
used. If no local file is specified, or if local-file
is `-', the output is sent to the terminal.
macdef macro-name
Define a macro. Subsequent lines are stored as the
macro macro-name; a null line (consecutive NEWLINE
characters in a file or RETURN characters from the ter-
minal) terminates macro input mode. There is a limit
of 16 macros and 4096 total characters in all defined
macros. Macros remain defined until a close command is
executed.
The macro processor interprets `$' and `\' as special
characters. A `$' followed by a number (or numbers) is
replaced by the corresponding argument on the macro
invocation command line. A `$' followed by an `i'
signals that macro processor that the executing macro
is to be looped. On the first pass `$i' is replaced by
the first argument on the macro invocation command
line, on the second pass it is replaced by the second
argument, and so on. A `\' followed by any character
is replaced by that character. Use the `\' to prevent
special treatment of the `$'.
mdelete [ remote-files ]
Delete the remote-files on the remote machine.
mdir remote-files local-file
Like dir, except multiple remote files may be speci-
fied. If interactive prompting is on, ftp will prompt
the user to verify that the last argument is indeed the
target local file for receiving mdir output.
mget remote-files
Expand the remote-files on the remote machine and do a
get for each file name thus produced. See glob for
details on the filename expansion. Resulting file
names will then be processed according to case, ntrans,
and nmap settings. Files are transferred into the
local working directory, which can be changed with
`lcd directory'; new local directories can be created
with `! mkdir directory'.
mkdir directory-name
Make a directory on the remote machine.
mls remote-files local-file
Like ls(1V), except multiple remote files may be speci-
fied. If interactive prompting is on, ftp will prompt
the user to verify that the last argument is indeed the
target local file for receiving mls output.
mode [ mode-name ]
Set the "transfer mode" to mode-name. The only valid
mode-name is stream, which corresponds to the default
"stream" mode.
mput local-files
Expand wild cards in the list of local files given as
arguments and do a put for each file in the resulting
list. See glob for details of filename expansion.
Resulting file names will then be processed according
to ntrans and nmap settings.
nmap [ inpattern outpattern ]
Set or unset the filename mapping mechanism. If no
arguments are specified, the filename mapping mechanism
is unset. If arguments are specified, remote filenames
are mapped during mput commands and put commands issued
without a specified remote target filename. If argu-
ments are specified, local filenames are mapped during
mget commands and get commands issued without a speci-
fied local target filename.
This command is useful when connecting to a non-UNIX-
system remote host with different file naming conven-
tions or practices. The mapping follows the pattern
set by inpattern and outpattern. inpattern is a tem-
plate for incoming filenames (which may have already
been processed according to the ntrans and case set-
tings). Variable templating is accomplished by includ-
ing the sequences $1, $2, ..., $9 in inpattern. Use \
to prevent this special treatment of the $ character.
All other characters are treated literally, and are
used to determine the nmap inpattern variable values.
For example, given inpattern $1.$2 and the remote file
name mydata.data, $1 would have the value "mydata", and
$2 would have the value "data".
The outpattern determines the resulting mapped
filename. The sequences $1, $2, ..., $9 are replaced
by any value resulting from the inpattern template.
The sequence $0 is replaced by the original filename.
Additionally, the sequence `[seq1,seq2]' is replaced by
seq1 if seq1 is not a null string; otherwise it is
replaced by seq2.
For example, the command `nmap $1.$2.$3
[$1,$2].[$2,file]' would yield the output filename
myfile.data for input filenames myfile.data and
myfile.data.old, myfile.file for the input filename
myfile, and myfile.myfile for the input filename
.myfile. SPACE characters may be included in outpat-
tern, as in the example `nmap $1 | sed "s/ *$//" >
$1'. Use the \ character to prevent special treatment
of the `$', `[', `]' and `,' characters.
ntrans [ inchars [ outchars ] ]
Set or unset the filename character translation mechan-
ism. If no arguments are specified, the filename char-
acter translation mechanism is unset. If arguments are
specified, characters in remote filenames are
translated during mput commands and put commands issued
without a specified remote target filename, and charac-
ters in local filenames are translated during mget
commands and get commands issued without a specified
local target filename.
This command is useful when connecting to a non-UNIX-
system remote host with different file naming conven-
tions or practices. Characters in a filename matching
a character in inchars are replaced with the
corresponding character in outchars. If the
character's position in inchars is longer than the
length of outchars, the character is deleted from the
file name.
open host [ port ]
Establish a connection to the specified host FTP
server. An optional port number may be supplied, in
which case, ftp will attempt to contact an FTP server
at that port. If the auto-login option is on
(default), ftp will also attempt to automatically log
the user in to the FTP server (see below).
prompt
Toggle interactive prompting. Interactive prompting
occurs during multiple file transfers to allow the user
to selectively retrieve or store files. By default,
prompting is turned on. If prompting is turned off,
any mget or mput will transfer all files, and any
mdelete will delete all files.
proxy ftp-command
Execute an FTP command on a secondary control connec-
tion. This command allows simultaneous connection to
two remote FTP servers for transferring files between
the two servers. The first proxy command should be an
open, to establish the secondary control connection.
Enter the command `proxy ?' to see other FTP commands
executable on the secondary connection.
The following commands behave differently when prefaced
by proxy: open will not define new macros during the
auto-login process, close will not erase existing macro
definitions, get and mget transfer files from the host
on the primary control connection to the host on the
secondary control connection, and put, mput, and append
transfer files from the host on the secondary control
connection to the host on the primary control connec-
tion.
Third party file transfers depend upon support of the
PASV command by the server on the secondary control
connection.
put local-file [ remote-file]
Store a local file on the remote machine. If remote-
file is left unspecified, the local file name is used
after processing according to any ntrans or nmap set-
tings in naming the remote file. File transfer uses
the current settings for "representation type", "file
structure", and "transfer mode".
pwd Print the name of the current working directory on the
remote machine.
quit A synonym for bye.
quote arg1 arg2 ...
Send the arguments specified, verbatim, to the remote
FTP server. A single FTP reply code is expected in
return.
recv remote-file [ local-file]
A synonym for get.
remotehelp [ command-name ]
Request help from the remote FTP server. If a
command-name is specified it is supplied to the server
as well.
rename from to
Rename the file from on the remote machine to have the
name to.
reset
Clear reply queue. This command re-synchronizes
command/reply sequencing with the remote FTP server.
Resynchronization may be necessary following a viola-
tion of the FTP protocol by the remote server.
rmdir directory-name
Delete a directory on the remote machine.
runique
Toggle storing of files on the local system with unique
filenames. If a file already exists with a name equal
to the target local filename for a get or mget command,
a `.1' is appended to the name. If the resulting name
matches another existing file, a `.2' is appended to
the original name. If this process continues up to
`.99', an error message is printed, and the transfer
does not take place. The generated unique filename
will be reported. Note: runique will not affect local
files generated from a shell command (see below). The
default value is off.
send local-file [ remote-file ]
A synonym for put.
sendport
Toggle the use of PORT commands. By default, ftp will
attempt to use a PORT command when establishing a con-
nection for each data transfer. The use of PORT com-
mands can prevent delays when performing multiple file
transfers. If the PORT command fails, ftp will use the
default data port. When the use of PORT commands is
disabled, no attempt will be made to use PORT commands
for each data transfer. This is useful when connected
to certain FTP implementations that ignore PORT com-
mands but incorrectly indicate they have been accepted.
status
Show the current status of ftp.
struct [ struct-name ]
Set the "file structure" to struct-name. The only
valid struct-name is file, which corresponds to the
default "file" structure.
sunique
Toggle storing of files on remote machine under unique
file names. The remote FTP server must support the
STOU command for successful completion. The remote
server will report the unique name. Default value is
off.
tenex
Set the "representation type" to that needed to talk to
TENEX machines.
trace
Toggle packet tracing (unimplemented).
type [ type-name ]
Set the "representation type" to type-name. The valid
type-names are ascii for "network " ASCII", binary or
image for "image", and tenex for "local byte size" with
a byte size of 8 (used to talk to TENEX machines). If
no type is specified, the current type is printed. The
default type is "network " ASCII".
user user-name [ password ] [ account ]
Identify yourself to the remote FTP server. If the
password is not specified and the server requires it,
ftp will prompt the user for it (after disabling local
echo). If an account field is not specified, and the
FTP server requires it, the user will be prompted for
it. If an account field is specified, an account
command will be relayed to the remote server after the
login sequence is completed if the remote server did
not require it for logging in. Unless ftp is invoked
with "auto-login" disabled, this process is done
automatically on initial connection to the FTP server.
verbose
Toggle verbose mode. In verbose mode, all responses
from the FTP server are displayed to the user. In
addition, if verbose mode is on, when a file transfer
completes, statistics regarding the efficiency of the
transfer are reported. By default, verbose mode is on
if ftp's commands are coming from a terminal, and off
otherwise.
? [ command ]
A synonym for help.
Command arguments which have embedded spaces may be quoted
with quote (") marks.
If any command argument which is not indicated as being
optional is not specified, ftp will prompt for that argu-
ment.
ABORTING A FILE TRANSFER
To abort a file transfer, use the terminal interrupt key
(usually CTRL-C). Sending transfers will be immediately
halted. Receiving transfers will be halted by sending a ftp
protocol ABOR command to the remote server, and discarding
any further data received. The speed at which this is
accomplished depends upon the remote server's support for
ABOR processing. If the remote server does not support the
ABOR command, an "ftp>" prompt will not appear until the
remote server has completed sending the requested file.
The terminal interrupt key sequence will be ignored when ftp
has completed any local processing and is awaiting a reply
from the remote server. A long delay in this mode may
result from the ABOR processing described above, or from
unexpected behavior by the remote server, including viola-
tions of the ftp protocol. If the delay results from unex-
pected remote server behavior, the local ftp program must be
killed by hand.
FILE NAMING CONVENTIONS
Local files specified as arguments to ftp commands are pro-
cessed according to the following rules.
1) If the file name `-' is specified, the standard input
(for reading) or standard output (for writing) is used.
2) If the first character of the file name is `|', the
remainder of the argument is interpreted as a shell
command. ftp then forks a shell, using popen(3S) with
the argument supplied, and reads (writes) from the
standard output (standard input) of that shell. If the
shell command includes SPACE characters, the argument
must be quoted; for example `"| ls -lt"'. A particu-
larly useful example of this mechanism is: `dir |
more'.
3) Failing the above checks, if "globbing" is enabled,
local file names are expanded according to the rules
used in the csh(1); see the glob command. If the ftp
command expects a single local file (for example, put),
only the first filename generated by the "globbing"
operation is used.
4) For mget commands and get commands with unspecified
local file names, the local filename is the remote
filename, which may be altered by a case, ntrans, or
nmap setting. The resulting filename may then be
altered if runique is on.
5) For mput commands and put commands with unspecified
remote file names, the remote filename is the local
filename, which may be altered by a ntrans or nmap set-
ting. The resulting filename may then be altered by
the remote server if sunique is on.
FILE TRANSFER PARAMETERS
The FTP specification specifies many parameters which may
affect a file transfer.
The "representation type" may be one of "network " ASCII",
"EBCDIC", "image", or "local byte size" with a specified
byte size (for PDP-10's and PDP-20's mostly). The "network
" ASCII" and "EBCDIC" types have a further subtype which
specifies whether vertical format control (NEWLINE charac-
ters, form feeds, etc.) are to be passed through ("non-
print"), provided in TELNET format ("TELNET format con-
trols"), or provided in ASA (FORTRAN) ("carriage control
(ASA)") format. ftp supports the "network " ASCII" (subtype
"non-print" only) and "image" types, plus "local byte size"
with a byte size of 8 for communicating with TENEX machines.
The "file structure" may be one of "file" (no record struc-
ture), "record", or "page". ftp supports only the default
value, which is "file".
The "transfer mode" may be one of "stream", "block", or
"compressed". ftp supports only the default value, which is
"stream".
SEE ALSO
csh(1), ls(1V), rcp(1C), tar(1), popen(3S), netrc(5),
ftpd(8C)
BUGS
Correct execution of many commands depends upon proper
behavior by the remote server.
An error in the treatment of carriage returns in the 4.2 BSD
code handling transfers with a "representation type" of
"network " ASCII" has been corrected. This correction may
result in incorrect transfers of binary files to and from
4.2 BSD servers using a "representation type" of "network "
ASCII". Avoid this problem by using the "image" type.