Chinaunix首页 | 论坛 | 博客
  • 博客访问: 128548
  • 博文数量: 20
  • 博客积分: 1455
  • 博客等级: 上尉
  • 技术积分: 230
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-04 22:09
文章分类
文章存档

2011年(3)

2008年(17)

我的朋友

分类: 系统运维

2008-03-12 23:16:40

by shenzhenlinux

ini 080110

rev 080304

 

FTP

FTPFile Transfer Protocol(文件传输协议)的缩写,用来在两台计算机之间互相传送文件。相比于HTTPFTP协议要复杂得多。复杂的原因,是因为FTP协议要用到两个TCP连接,一个是命令链路,用来在FTP客户端与服务器之间传递命令;另一个是数据链路,用来上传或下载数据。

 

PORT & PASV

    FTP协议有两种工作方式:PORT方式和PASV方式,中文意思为主动式和被动式。

    PORT(主动)方式的连接过程是:客户端向服务器的FTP端口(默认是21)发送连接请求,服务器接受连接,建立一条命令链路。当需要传送数据时,客户端在命令链路上用PORT命令告诉服务器:“我打开了XXXX端口,你过来连接我”。于是服务器从20端口向客户端的XXXX端口发送连接请求,建立一条数据链路来传送数据。

    PASV(被动)方式的连接过程是:客户端向服务器的FTP端口(默认是21)发送连接请求,服务器接受连接,建立一条命令链路。当需要传送数据时,服务器在命令链路上用PASV命令告诉客户端:“我打开了XXXX端口,你过来连接我”。于是客户端向服务器的XXXX端口发送连接请求,建立一条数据链路来传送数据。

    从上面可以看出,两种方式的命令链路连接方法是一样的,而数据链路的建立方法就完全不同。而FTP的复杂性就在于此。

 

使用FTP客户端的注意事项

    请注意:选择用PASV方式还是PORT方式登录FTP服务器,选择权在FTP客户端。

一、客户端只有内网IP,没有公网IP

    从上面的FTP基础知识可知,如果用PORT方式,因为客户端没有公网IPFTP将无法连接客户端建立数据链路。因此,在这种情况下,客户端必须要用PASV方式,才能连接FTP服务器。大部分人登录不上,典型的错误原因就是因为客户端没有公网IP,但用了IE作为FTP客户端来登录(IE默认使用PORT方式)。

 

二、客户端有公网IP,但安装了防火墙

    如果用PASV方式登录FTP服务器,因为建立数据链路的时候,是由客户端向服务器发送连接请求,没有问题。反过来,如果用PORT方式登录FTP服务器,因为建立数据链路的时候,是由服务器向客户端发送连接请求,此时连接请求会被防火墙拦截。如果要用PORT方式登录FTP服务器,请在防火墙上打开1024以上的高端端口。

 

三、常见的FTP客户端软件PORT方式与PASV方式的切换方法。

    大部分FTP客户端默认使用PASV方式。IE默认使用PORT方式。

    在大部分FTP客户端的设置里,常见到的字眼都是“PASV”或“被动模式”,极少见到“PORT”或“主动模式”等字眼。因为FTP的登录方式只有两种:PORTPASV,取消PASV方式,就意味着使用PORT方式。

 

IE

    工具 -> Internet选项 -> 高级 -> “使用被动FTP”(需要IE6.0以上才支持)。如果找不到这个选项,请看 图片。

 

CuteFTP

    Edit -> Setting -> Connection -> Firewall -> “PASV Mode”

File -> Site Manager,在左边选中站点 -> Edit -> Use PASV mode

 

FlashGet

    工具 -> 选项 -> 代理服务器 -> 直接连接 -> 编辑 -> PASV模式”

 

FlashFXP

    选项 -> 参数选择 -> 代理/防火墙/标识 -> “使用被动模式”

或站点管理 -> 对应站点 -> 选项 -> “使用被动模式”

或快速连接 -> 切换 -> “使用被动模式”

 

LeechFTP

    Option -> Firewall -> Do not Use

 

四、请尽量不要用IE作为FTP客户端

    IE只是个很粗糙的FTP客户端工具。首先,IE6.0以下的版本不支持PASV方式;其次,IE在登录FTP的时候,看不到登录信息。在登录出错的时候,无法找到错误的原因。在测试的时候,强烈建议不要使用IE

阅读(2917) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~