ftp客户端的设计与实现
专用FTP客户端系统的设计与实现

( 27 0 2 0 牟第 年第 期
L B R T R S IN E A O A O Y CE C
2 7 月出 0 年4 0 版
专 用 F P客 端 T 户 系统 的设 计 与 实现
田胜 利
( 昌学 院计算 机科 学技 术 学 院 许
关键 词 : 三层 架构 ;r 局域 网教 学 F P; r
随着 I e e 的普及 , nm t t 信息的交互传输显得越来 越重要 。在 局域 网中 , 我们通 过共享 文件夹 , 利用 网 络邻居进行信息共享 、 。在广域网中, r e 传输 我 ̄ s 常 i 用 z P Fl Tas r r oa) r ( i r f o c1进行 网络上信息 的传 e neP t 输和管理 。笔者在教 学实践 中发现无论 是利 用 网络 邻居还是 F P r 进行信息传输和管理 , 在实际应用中 都 有不尽如 人意 的地 方 , 比如 : 学 生 的上 机课 上 , 在 老师会布置一 些 实验 作 业 , 些 实验 作业 同学们 往 这 往一次两次课做不完。因此, 同学们会把未做完 的 作业保存起来 , 下次接着做。等下次上课时 , 同学很 可 能不会再使用上 次保存文 件 的机 器 。即便使用 的 是 同一 台机器 , 也很 可 能会 发现 自己的作 业 已被 删 除。并且 有 的机房 为 了安全 管理 , 取 了一 些措 施 , 采 禁止使用软盘或使用硬盘保护卡 , 使得信息不能保 存在 软盘 或本地机 器上 。有 的机房还 有可能 使用 的 是无盘工作 站 , 也会 出现类 似 的 问题 。平 时老 师会 在教师机上 安装 F P软件并 为 同学们建 立公用 的用 r 户名 、 密码 , 求 同学们 把作业通过 F P上传 到教师 要 T r 机上。因为利用 F P T 上传的信息 , r 你自己上传 、 可能 需 要下载 、 更新 或删 除 , 而其他 同学 同样 有这些 操作 权限, 若老师 为每个 同学建 立一个 用户 名 、 密码 且赋 予不同的权限 , 以解决这一问题。但是这样做比 可 较 麻烦 ( 工作 量 较 大 ) 。有 时 任课 老 师 会 在 教师 机 上 为每个 同学建 立共享 文件夹设置 共享 密码并 告诉 该同学, 使之通过网上邻居进行信息传输 , 显然该方 法也 比较麻烦且存 在一些 其它 问题 。这样 的例子 很 多 , 就不一一枚举 。鉴 于以上 情况 , 过认 真思 这里 经 考, 笔者 找到 了一种 解 决上 述 问 题 的方 法 。那 就 是 做一个专 用 的 F P客户 端软 件 , 用户 可 以 自己管 T r 使 理 自己上 传 的信息并 设置操作 权限 。 1 目前流行 的 F P服务器 软件和客 户端软件 . T r 目前 F P T 服务器端的软件 比较多 , U i操作 r 象 n x 系统 下 的 WU ̄P I'D软 件 、 no s操 作 系 统 下 的 q Widw Sr u( 国生 产 ) ev— 美 的软件 、adn l D( 国台湾 R i F' 中 e P
毕业设计论文-IPv6环境下FTP系统的设计与实现(含源程序代码)

毕业设计(论文)IPv6环境下FTP系统的设计与实现毕业设计(论文)中文摘要IPv6环境下FTP系统的设计与实现摘要IPv4是目前广泛使用的互联网IP技术,IPv6则是下一代的IP协议,注入了许多新的内容。
随着互联网技术的不断发展,IP协议将慢慢从IPv4过渡到IPv6。
文件传输协议是互联网上广泛使用的在远程计算机系统和本地计算机系统之间传输文件的标准。
因此,本次毕业设计研究在IPv6环境下FTP系统的设计与实现。
本设计首先阐述了IPv6的发展状况,然后介绍了IPv6协议在各流行操作系统下的安装与配置,最后按照RFC959-《标准文件传输协议》和RFC2428-《FTP对IPv6和NAT的扩展》的要求,采用支持IPv6 Socket编程的JDK5.0,实现了绝大部分的FTP传输命令,包括一个服务端与一个客户端程序,经测试,均可工作于IPv4与IPv6环境。
关键字:IPv6 FTP C/S JDK5.0毕业设计(论文)外文摘要The Design and Implement of FTP System Base on IPv6 EnvironmentAbstract: While IPv4 is widely used technique at present in the internet, IPv6 is the next generation Internet Protocol that brings many new contents. Along with the development of internet technique, transition from IPv4 to IPv6 is necessary though maybe slowly. File Transfer Protocol is widely used in internet and is the standard of transfer file between remote computer system and local computer system. Consequently, I investigate the design and implement of ftp system in IPv6 environment.This paper first expounds the development of IPv6,then introduces IPv6's installation and configuration on popular operation systems, finally according to RFC595-<FILE TRANSFER PROTOCOL> and RFC2428-<FTP Extensions for IPv6 and NATs>,with JDK5.0 which supports IPv6 socket programming, implements a majority of FTP commands. This design presents a server site and a client site, which can work on IPv4 and IPv6 environment.Keywords: IPv6;FTP;C/S;JDK5.0目录1 引言 (1)1.1 课题的研究背景与意义 (1)1.1.1 课题的研究背景 (1)1.1.2 课题的研究意义 (2)1.2 问题定义及内容简介 (2)1.2.1 问题定义 (2)1.2.2 问题的内容简介 (2)1.3 课题调研与可行性分析 (3)1.3.1 课题调研 (3)1.3.2 可行性分析 (3)1.4 论文各章内容介绍 (4)2 系统需求分析 (5)2.1 IPv6发展现状 (5)2.2 系统环境的搭建 (9)2.3 基于C/S模型的网络开发 (9)2.4 支持IPv6的Socket编程 (12)3 文件传输协议 (15)3.1 介绍 (15)3.2 概览 (15)3.3 FTP的传输模式 (16)3.4 FTP的工作方式 (16)3.5 文件传输功能 (17)3.6 说明 (21)4 FTP对IPv6和NAT的扩展 (24)4.1 介绍 (24)4.2 EPRT命令 (24)4.3 EPSV命令 (25)4.4 命令使用 (25)5 FTP服务器的实现 (27)5.1 总体设计 (27)5.2 详细设计 (27)5.2.1 主函数设计 (27)5.2.2 服务线程 (27)5.2.3 其他主要命令 (30)5.2.4 数据库设计 (33)5.2.5 界面设计 (33)5.3 服务器测试 (33)6 FTP客户端的实现 (37)6.1 方案的选择 (37)6.2 界面的设计 (37)6.3 几个重要的类 (38)6.4 实现步骤 (38)7 用户使用手册 (40)7.1 系统功能简介 (40)7.2 运行环境简介 (40)7.2.1 系统环境配置 (40)7.2.2 JDK环境变量配置 (42)7.2.3 SQL Server2000的有关配置 (42)8 系统评价 (44)8.1 系统特色/优点介绍 (44)8.2 系统存在的不足与改进方案 (44)8.2.1 系统存在的不足 (44)8.2.2 系统的改进方案 (44)结论 (45)致谢 (46)参考文献 (47)1 引言1.1 课题的研究背景与意义1.1.1 课题的研究背景现有的互联网主要是基于IPv4协议的。
FTP(文件传输协议)的原理与实现

FTP(文件传输协议)的原理与实现FTP,即文件传输协议(File Transfer Protocol),是一种用于在计算机网络中进行文件传输的应用层协议。
它允许用户通过客户端和服务器之间进行文件的上传、下载和删除等操作。
本文将介绍FTP的原理和实现。
一、FTP的原理FTP的原理基于客户端-服务器(client-server)模型。
客户端和服务器通过FTP协议进行通信,客户端发出命令请求,服务器进行相应的处理并返回结果。
FTP采用不同的连接来进行数据传输和命令传输。
1. 命令传输连接命令传输连接是客户端和服务器之间进行命令交互的通道。
客户端通过该连接发送各种FTP命令,如登录、目录操作、文件操作等。
服务器接收到命令后执行对应的操作,并返回结果给客户端。
该连接使用TCP协议的默认端口号21。
2. 数据传输连接数据传输连接用于在客户端和服务器之间传输文件内容。
FTP支持两种方式的数据传输:主动模式(Active Mode)和被动模式(Passive Mode)。
- 主动模式:客户端向服务器发起数据传输连接,在该连接上进行文件的传输。
客户端随机选择一个端口并通过PORT命令告知服务器。
服务器返回连接确认请求,然后在该连接上进行数据的传输。
主动模式需要客户端开放一个端口用于接收服务器的连接。
- 被动模式:服务器向客户端发起数据传输连接,在该连接上进行文件的传输。
客户端发送PASV命令给服务器,服务器在随机开放的端口上等待客户端的连接。
客户端接收到服务器的地址和端口信息后,通过该地址和端口和服务器进行数据传输。
被动模式通过服务器来建立数据传输连接,适用于客户端无法开放端口的情况(如在防火墙后)。
通过命令传输连接和数据传输连接的组合,客户端和服务器可以实现文件的上传、下载和删除等功能。
二、FTP的实现FTP的实现涉及到客户端和服务器端的开发。
下面分别介绍两者的实现要点。
1. 客户端实现客户端实现主要包括以下几个方面的工作:- 用户界面设计:客户端需要提供一个用户界面供用户输入FTP服务器地址、用户名和密码等信息,并显示服务器返回的文件列表及操作结果等信息。
基于Serv-U的FTP设计与实现

第 3 期 1
S INC CE E&T C N O YI O MA I N E H OL G NF R T O
。l T论坛。
设计与实现 T
计 宏
( 安科技 大学 西
陕西
西安
70 5 1 0 4)
【 摘 要 】 述 了 F P和 Sr— 的 优 点 、 能和 工作 模 式 。 论 T e U v 功 阐述 了使 用 Sr— 建 立 F P服 务 和 访 问 F P站 点 的 方 法 和 步骤 , 出 了解 决 ev U T T 给 F TP服 务 安 全 问题 的措 施 。结 合 实际 案例 , 实现 了使 用 S r — 搭 建 F P站 点 的 功 能 , 用 户提 供 了安 全 高 效 的数 据 传 输 和 资 源 共 享 。 ev U T 为
号 ) 设 置 为 “ e ” A c u tl i a ( 录 名 ) 输 入 “s h o ak : Y s ; c o n o n n me 登 g : c oh s 的效 率 , 同时 ,网 上邻 居 ” “ 的性 能 不 稳 定 情 况 时有 发 生 , 出 现无 法 连 0 1 : a s od 密 码 ) w rh r 0 ; medrcoy 主 目 录 ) D f ; 常 0 ” P sw r ( : ok ad 0 1 Ho i t ( e r : At p 接 网络 计 算 机 , 法 正 常传 输 数 据 。使 用 F PSre 系统 使 上 面提 到 L c h sri eh m i co ( 用 户 锁 定 在 主 目录 中 )设 置 为 无 T e r r v o kteue t o edr t 将 nh e r y : 的 问题 迎 刃 而 解 “ e” A cu t d i r i g ( 号 管 理 权 限 ) Y s : con m np vl e 帐 a i e :设 置 为 默 认 值 “ No 11 F P 的 定 义 和 功 能 . T p vl e 。 Sr— i e r i g ” e U管 理 权 限 中 的 st hn epsw r ( 置 , 改 管理 v e/ ag as od 设 c 修 F P是 Fl rnfrPooo( 件 传 输 协 议 )通 过 Itre 使 网 T i Tase rtcl 文 e . nen t 员 密 码 ) 入 lv1ape 每 次 开 启 S r— 输 o e p l, y ev U需 输 入 该 密 码 。 了 提 高安 为 络 计 算 机 之 间 进行 安 全 有 效 地 数 据 传 输 。与 H1 P协 议 相 比 较 , P 全 性 . 密 码设 置 应 较 复 杂 。并 设 置 最 大上 传 速 率 、 大 下 载 速 率 、 T r 丌 该 最 连 协 议 则 复 杂 许 多 , 因 在 于 , TP协 议 要 用 到 两 个 T P连 接 , 原 fr C 一个 是 接 到 本 服 务器 的最 多 用 户 数 量 等 信 息 。 命 令 链 路 , 来 在 f PSre 与 盯 P Cin 之 间 传 递 命 令 ; 一 个 是 22 F P的管 理 用 T evr r l t e 另 . T 数 据链 路 , 来 上 传 或 下载 数 据 。 用 创 建 帐 户 sh o ak 0 、c ohsO 3到 sh ot k 5 ; 密 码 为 c ohs0 2 sh o ak 0 col s0 0 a 兀1 P的主 要 功 能 如 下 : P可 以 实现 多 种 格 式 、 种 类 型 、 多 多种 结 W rhr0 2 w rh d 0 od ad 0 、 od a 0 3到 w rhr0 0 r od ad 5 ;主 目 录 为 D f At 锁 定 于 p并 构 的 文 件 传 输 , 中 包 括 : 件 (i ) 记 录 ( eod , (ae ; 有 其 文 Fl , e R cr) 页 P g ) 具 主 目录 。 即 F P站点 共 设 置 了 5 T O个 帐 户 , 中用 户 sho ak 0 对 其 eoh s0 1 对 文 件 改 名 、 变 属 性 、 除 文件 、 示 内容 等 功 能 的 操作 ; 供 对 远 所 有 目录有 读 、 、 除 、 改 删 显 提 写 删 重命 名 等 最 高权 限 ; D: p下 建 立 子 目录 , 在 / i f 程 主 机 系 统 和本 地 计 算 机 系 统 的 目录安 全 操 作 功 能 ; 有 匿名 F P登 名 称 分 别 为 sf ae 、 l 、 an m s 、 h t 、 o i 、 0 、0 具 F ot r fe l r 、 u i p o m ve 0 1 0 2到 0 0 w i e c o 5。 陆 的 功 能 ;T evr F P ln 之 间 交 换 的 数 据 是 通 过 复 制 数 据 f PSre 与 T Ci t r r e 其 中 sf r fe 、 an mui、h t、 ve是 常 用 软 件 资 源 、 共 办 owae、l l r 、 s p oomoi t i e c 公 而 不 是 移 动 数 据 。F P协议 是 由 R C9 9Fl rnfr rtcl盯 P T F 5 i T as ooo( ) e eP 公 文 件 、 务 学 习 资 料 、 片 、 片 和 音 乐 资 源 , 些 数 据 资 源 由 站 点 业 影 照 这 定 义 的 , 主 要 目的 如 下 : 供 安 全 、 靠及 有 效 的 数 据 传 输 系统 ; 它 提 可 实 管 理 员 维 护 和更 新 .供 所 有 帐 户 浏 览 和 下 载 。 D/p0 2到 D/p00 :t/0 f :t/5 f 现 网 络 资 源 共 享 ;通 过 使 用 应 用 程 序 直 接 或 间 接 登 陆 和 使 用 远 程 主 是 对 应 的 用 户 sh o ak 0 c 0 I s 0 2到 s h o ak 5 的 个 人 空 问 。如 用 户 t c o h s0 0 机 ; 供一 致 性 的 协 议 , 免 用 户 在 不 同远 程 主 机 上 产 生 不 同 的操 作 提 避 sho ak0 e oh s0 2把 个 人 的 信 息 资 源 上 传 到 指 定 的 目 录 D/p0 2下 , :t/0 f 也 方 式『 J 1 。 可 以 对 该 目录下 的 文 件 进 行 删 除 和 重 命 名 , 除 管理 员 外 , 他 用 户 而 其 1 F P的 工 作 原理 . 2 T 对 该 目录和 文 件 只 有 浏 览 和 下 载 的权 限 。 上 通 过 实 例完 成 了 肿 的 综 F PCi t 起 fr T l n 发 e T P会 话 ,与 F PS re 建 立 相 应 的 两 个 连 接 。 T evr 初步搭建 。 F P会 话 期 间建 立 的 这 两 个 连 接 分别
VisualC++网络编程案例实战之FTP客户端

4.1.6 FTP常用命令
• 在实际编程中,有些复杂的操作,只是需要客 户端发送相关的指令到服务器执行即可。所以, 对于用户来说掌握常用的FTP命令是非常重要 的。下面列举了一些常用的FTP命令,如表4.3 所示。
表4.3 常用FTP命令及意义
FTP命令 LIST PWD RETR STOR STOU STRU MODE ABORT 意 义 发送当前工作目录下的文件名列表到客户端 显示服务器的当前工作目录名 从服务器下载一个文件 上传文本文件到服务器,如果文件存在会被覆盖 上传文本文件到服务器,但不会覆盖已经存在的文件 设置文件的结构 指定数据的传输模式 通知服务器关闭连接
第4章 FTP客户端
• 本章将带领大家编写一个简单的FTP客户端程 序,实现简单的功能:登录FTP服务器,处理 服务器上的文件,如上传、下载,最后安全退 出服务器。先弄清楚原理,然后我们再考虑怎 样去实现。
4.1 FTP工作原理
• FTP的工作原理跟TCP一样,客户端需要先与 服务器连接,等待服务器的应答,最后再建立 数据通道。所以,FTP浏览器在和服务器建立 连接时也需要经过“三次握手”的过程。这表 示客户端与服务器之间的连接是可靠、安全的, 这也为数据传输提供了可靠的保证。FTP的工 作原理如图4.1所示。
图 4.1 FTP工作原理图
4.1.1 FTP数据结构
• 进行FTP编程之前,用户首先需要知道FTP有哪些 数据结构。由于在某些主机上保存的文件是面向 字节的,某些是面向记录的。所以在FTP中,除 了有不同的数据类型以外,还有几种不同的文件 结构类型。这样做的目的是为了在不同的主机之 间传送文件时能够相互识别。 • 二进制结构:文件中没有内部结构,一般被看作 二进制流。 • 文件式结构:由许多记录组成的文件。 • 页面结构:由不同的索引页组成文件。 • 注意:一般情况下,如果没有使用FTP命令去 设置文件的结构,则默认的结构是文件式结构。
安全FTP系统的设计与实现

靠且有效的数据传输等 , 应用 非常广泛 。但 是传统 的 F ’ T I P有 不少的安全漏洞 , 例如 明文传输 、 缺乏对数据 的机密性和完整性 保护 , 对通信双方也没有可靠 的认证措 施等 。针 对 F P的安全 T
漏洞 , 近年来也 出现 了一 些不需 要对 FP协议 自身 做完 全更改 I
关键 词 F P 安全 T r SL 加 密 S O P B S 6 T A E4
DES GN I AND M PLEM ENTATI I oN F A ECURE o S FTP YSTEM S
M a Ya Li at o Ba n c i n u H ia iYi g a ( co lfI om t nScryE gnei S ag a ioog U i rt,h nh i 0 0 0,hn ) Sho n rai eui n i r g,h nh i a t nv sy S ag 0 3 C ia o f o t e n J n ei a 2
Ab t a t sr c Fr sa p oo o ih c n ta se ls b t e o u e s c n e in l n a e n w d l s d Ho v r t e e a e lt f T P i r tc l wh c a r n f rf e ewe n c mp tr o v n e t a d h sb e i ey u e . we e .h r r o so i y
传输都在 S L通道里进行 。 S ( )用户认证 , 2 通过 ( sma , T , S 三元组 进行 , 中 U e me O P D ) 其
O P( n i as o ) 指 一 次 性 密 码 , S Dsa S ntr) T O e mePsw r 是 T d D ( i t i a e l g u
FTP客户端的设计与实现

FTP客户端的设计与实现1. 简介FTP(File Transfer Protocol)是一种用于文件传输的标准协议。
FTP客户端是指使用FTP协议与FTP服务器进行通信并传输文件的程序。
在本文中,我们将探讨FTP客户端的设计与实现。
2. 设计2.1 功能需求FTP客户端的主要功能需求包括:1.连接到FTP服务器2.在FTP服务器和本地电脑之间传输文件3.列出FTP服务器上的文件和目录4.创建和删除FTP服务器上的目录5.重命名FTP服务器上的文件6.支持多种操作系统(如Windows、Linux等)2.2 架构设计FTP客户端采用MVC(Model-View-Controller)模式来设计,其中:•Model层:管理FTP客户端的业务与数据逻辑。
提供FTP相关的API,封装了FTP协议的底层实现。
•View层:处理和呈现用户界面。
•Controller层:处理用户请求,调用Model层实现相关业务逻辑。
2.3 技术选型FTP客户端的技术选型如下:•编程语言:Java•GUI框架:JavaFX•FTP库:Apache Commons Net•构建工具:Maven•版本控制:Git2.4 待解决问题FTP客户端在设计中会遇到以下问题:1.如何扩展支持更多的FTP协议?2.如何实现可靠的文件传输?3.如何提高用户界面的体验?3. 实现3.1 界面实现使用JavaFX框架实现FTP客户端的用户界面。
主要界面包括:•登录界面:输入FTP服务器地址、用户名和密码登录FTP服务器。
•主界面:显示FTP服务器上的文件和目录,并提供文件传输和操作的操作界面。
3.2 功能实现FTP客户端通过Apache Commons Net库实现FTP底层协议。
实现的功能包括:1.连接到FTP服务器FTPClient ftp = new FTPClient();ftp.connect(server, port);ftp.login(username, password);2.在FTP服务器和本地电脑之间传输文件ftp.retrieveFile(remoteFile, localFile);ftp.storeFile(remoteFile, localFile);3.列出FTP服务器上的文件和目录FTPFile[] files = ftp.listFiles(remoteDir);4.创建和删除FTP服务器上的目录ftp.mkd(remoteDir);ftp.rmd(remoteDir);5.重命名FTP服务器上的文件ftp.rename(from, to);4. 总结通过对FTP客户端的设计与实现,我们了解了FTP协议的底层实现和FTP客户端的主要功能。
FTP客户端(1)

目录1 引言 (1)2 FTP简介 (1)2.1 FTP简介 (1)2.2 FTP工作原理 (1)3 系统分析及配置 (2)3.1 Ftp客户端设计思想 (2)3.2服务端配置-操作系统IIS安装 (3)4 FTP客户端概要设计 (5)4.1系统模块 (5)4.2系统功能 (5)4.3主要数据结构分析 (5)4.4程序界面设计 (6)5 详细设计及主要代码 (7)5.1设置列表控件的风格 (7)5.2对话框初始化 (8)5.3实现客户端连接到FTP服务器 (8)5.4列出FTP服务器目录 (9)5.5退出FTP服务器 (11)6 测试运行 (12)6.1登陆界面 (12)6.2列出服务器目录 (12)6.3退出服务器 (12)7总结 (12)参考文献 (13)1 引言FTP是Internet上用来传送文件的协议,它是为了我们能够在Internet上互相转送文件而制定的文件转送标准,规定了Internet上文件如何传送,通过FTP协议,我们可以跟Internet 上的FTP服务器进行文件上传或下载。
本实验以实现一个简单的FTP客户端为目标,实验目的是:1)熟悉网络应用层的传输协议,增强对FTP协议的了解;2)提高自己的动手能力以及编程能力;3)掌握vc和提高对MFC界面制作能力。
本次试验的要求如下:1)要求实现的程序为图形化界面,可以输入FTP服务的相关信息(包括IP地址、用户名与密码),输出交互过程中的FTP命令与响应信息,以及从FTP服务器的根目录获得的文件(或目录)列表。
2)要求遵循RFC959的相关FTP协议规定。
只要求实现USER、PASS、PASV、LIST 和QUIT命令。
点击Connect按钮,实现USER与PASS命令;点击LIST按钮,实现PASV 与LIST命令;点击Quit按钮,实现QUIT命令。
3)要求有良好的编程规范与注释信息。
4)要求有详细的说明文档,包括程序的设计思想、工作流程、关键问题等。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
《计算机网络》课程设计说明书题目: ftp客户端的设计与实现学院:计算机科学与工程学院专业:信息安全2015年03 月24日摘要与大多数Internet服务一样,FTP也是一个客户机/服务器系统。
用户通过一个支持FTP协议的客户机程序,连接到在远程主机上的FTP服务器程序。
用户通过客户机程序向服务器程序发出命令,服务器程序执行用户所发出的命令,并将执行的结果返回到客户机。
比如说,用户发出一条命令,要求服务器向用户传送某一个文件的一份拷贝,服务器会响应这条命令,将指定文件送至用户的机器上。
客户机程序代表用户接收到这个文件,将其存放在用户目录中。
在FTP的使用当中,用户经常遇到两个概念:“下载”(Download)和“上载”(Upload)。
“下载”文件就是从远程主机拷贝文件至自己的计算机上;“上载”文件就是将文件从自己的计算机中拷贝至远程主机上。
用Internet语言来说,用户可通过客户机程序向(从)远程主机上载(下载)文件。
使用FTP时必须首先登录,在远程主机上获得相应的权限以后,方可上载或下载文件。
也就是说,要想同哪一台计算机传送文件,就必须具有哪一台计算机的适当授权。
换言之,除非有用户ID和口令,否则便无法传送文件。
这种情况违背了Internet的开放性,Internet上的FTP主机何止千万,不可能要求每个用户在每一台主机上都拥有帐号。
匿名FTP就是为解决这个问题而产生的。
匿名FTP是这样一种机制,用户可通过它连接到远程主机上,并从其下载文件,而无需成为其注册用户。
系统管理员建立了一个特殊的用户ID,名为anonymous,Internet上的任何人在任何地方都可使用该用户ID。
关键字:FTP;java;远程连接;上传;下载引言 (4)1、系统概述 (4)1.1、系统说明.................................................... 错误!未定义书签。
1.2、系统功能说明................................................ 错误!未定义书签。
2、需求分析 (4)2.1、系统需求 (8)2.2、开发环境 (8)3、详细设计................................................ 错误!未定义书签。
3.1、系统设计.................................................... 错误!未定义书签。
3.2、各模块详细设计.............................................. 错误!未定义书签。
3.2.1、图形界面模块 ................................ 错误!未定义书签。
3.2.2、连接登录模块 ................................ 错误!未定义书签。
3.2.3、浏览模块 .................................... 错误!未定义书签。
3.2.4、上传和下载模块 .............................. 错误!未定义书签。
3.2.5、程序总体功能测试 ............................ 错误!未定义书签。
4、所遇到的问题和分析解决.................................. 错误!未定义书签。
5、结论.................................................... 错误!未定义书签。
参考文献................................................... 错误!未定义书签。
引言随着科学技术的不断提高,计算机网络日渐成熟,其强大的功能已为人们深刻认识,它已进人类社会的各个领域并发挥着越来越重要的作用。
其中的文件传输协议(File Transfer Protocol, FTP)是目前Internet上使用得最广泛的文件传送协议。
在互联网早期曾占据整个互联网通信量的三分之一。
它主要解决了在不同操作系统下处理文件格式的不兼容性。
起初,FTP并不是应用于IP网络上的协议,而是20世纪60~80年代美国国防部组建的ARPANET网络中,用于计算机间的文件传输的协议。
时至今日,FTP仍然保持其可靠性,高速地传输文件,它还允许文件远程存取。
这使得用户可以在某个系统上工作,而将文件存贮在别的系统。
传统方式需要在DOS下输入命令,对于普通用户是件极困难的事。
为了用户更方便的使用FTP服务,提供更好的人机交互界面,本次课程设计将完成一个简单FTP客户端系统的设计和开发工作,实现服务器连接、远程与本地目录浏览、文件上传和下载等基本FTP工具常用功能。
并通过这次课程设计,对网络编程方面有更深入的了解,提高实践能力。
1 绪论1.1 研究背景FTP是Internet上最早也是最广的应用,直到今天它仍是最重要和最基本的应用之一。
用FTP将信息下载到本地是一件十分普遍的事。
也随之出现了许多下载软件。
尽管远程登录(Telnet)提供了访问远程文件的极好方法,但怎么也比不上使用自己计算机中的文件方便。
如果用户想使用其它计算机上的文件,最理想的方法就是把它COPY到自己的计算机中,以便在本地计算机上操作。
FTP 正是完成这项工作的工具,你可以在任意一个经过文件传输协议(FTP)访问的公共有效的联机数据库或文档中找到你想要的任何东西。
全世界现在已有1000多个(96年的数据)FTP文件服务器对所有INTERNET用户开使用,用户可以通过与Internet相连到远程计算机,把自己需要的文件传输过来或是把自己的收集传输上去与他人共享。
传统的数据库应用系统采用的是客户机/服务器(Client/Server)模式,有高度的交互性,高效的用户界面等优点1.2 主要工作通过客户端可以实现文件的上传和下载。
其促进文件的共享(计算机程序或数据)、鼓励间接或者隐式的使用远程计算机、向用户屏蔽不同主机中各种文件存储系统的细节和可靠和高效的传输数据。
1.3 本文结构本文第1部分绪论主要说明了研究背景、主要工作和本文结构。
第2部分说明了有关ftp的相关知识。
第三部分系统设计,绘制了系统的模块图、流程图和模块的实现。
第四部分系统的测试与数据分析,说明了测试遇到的问题、解决方法及系统进一步的优化。
第五部分是本课程设计的总结和体会。
2 相关知识介绍2.1 FTP 工作原理FTP(File Transfer Protocol),是文件传输协议的简称。
用于Internet 上的控制文件的双向传输。
同时,它也是一个应用程序。
用户可以通过它把自己机器与世界各地所有运FTP协议的服务器相连,访问服务器上的资源和信息。
FTP协议在TCP/IP协议栈中的位置如表1:当启动FTP从远程计算机拷贝文件时,事实上启动了两个程序:一个本地机器上的FTP客户端程序,它向FTP服务器提出拷贝文件的请求。
另一个是启动在远程计算机的上的FTP服务器程序,它响应请求把你指定的文件传送到你的计算机中。
FTP采用“客户端/服务器”方式,用户要在自己的本地计算机上安装FTP客户端程序。
从根本上说,FTP协议就是在网络中各种不同的计算机之间按照TCP/IP 协议来传输文件。
FTP协议采用客户端/服务器(Client/Sever)模式,由FTP客户端程序和FTP服务器端程序组成。
使用时,先启动FTP客户端程序与远程主机建立连接,然后向远程主机发出传输命令,远程主机在收到命令后就给予响应,并执行正确的命令。
但是FTP有一个根本的限制,那就是,如果用户在某个主机上没有注册获得授权,即没有用户名和口令,就不能与该主机进行文件传输。
但匿名FTP服务器除外,它能够使用户与远程主机建立连接并以匿名身份从远程主机上拷贝文件,而不必是该远程主机的注册用户。
用户使用特殊的用户名“Anonymous”或“guest”就可有限制地访问远程主机上公开的文件。
现在许多系统要求用户将Emai1地址作为口令,以便更好地对访问者进行跟综。
出于安全的目的,大部分匿名FTP主机一般只允许远程用户下载文件,而不允许上载文件。
也就是说,用户只能从匿名FTP主机拷贝其需要的文件而不能把文件拷贝到匿名FTP主机。
另外,匿名FTP主机还采用了其他一些保护措施以保护自己的文件不至于被用户修改和删除,并防止计算机病毒的侵入。
匿名FTP一直是Internet上获取信息资源的最主要方式,在Internet成千上万的匿名FTP主机中存储着无以计数的文件,这些文件包含了各种各样的信息、数据和软件。
人们只要知道特定信息资源的主机地址,就可以用匿名FTP登陆。
2.2 FTP工作模式FTP 采用C/S(客户端/服务器)模式进行通信,但与其他的C/S 模式网络通信协议又有一个很大的区别。
通常在进行HTTP 通信或是TELNET 通信的时候,只需要一个端口进行通信。
即客户端只需要连接一个端口进行数据通信。
如TELNET 的默认端口是23,用户从头到尾都只需使用这个端口。
但是FTP 通信除了有一个默认端口21 之外,还需要其他的端口。
其中默认端口(21)主要进行控制连接,进行命令协议和服务器端的响应码的传输;另外一个非标准端口主要进行数据传递,如文件的上载、下载等。
至于非标准端口的产生则要根据用户选择的连接模式而定:如果客户选择的是主动模式(PORT),则需要用户端提供给服务器一个IP 地址和一个非标准端口;而如果用户采用被动模式(PASV),则服务器端需要提供给客户端一个IP 地址和一个非标准端口。
下表是几个著名的TCP 端口号:表2 TCP 端口号FTP 中字节大小有两个:逻辑字节大小和用于传输的字节大小。
后者通常是8 位,而前者可不一定是多少了。
传输字节不必等于逻辑字节大小,也不必对数据结构进行解释。
控制连接是建立在USER-PIT 和SERVER-PI 之间用于交换命令与应答的通信链路。
数据连接是传输数据的全双工连接,传输数据可以发生在服务器DTP 和用户DTP之间也可以发生在两个服务器DTP 之间,FTP 可以传输非连续的文件,这些文件的一部分称为页。
服务器DTP 代表一种传输过程,它通常处于“主动”状态,它和侦听端口建立数据连接,它还可以为传输和存储设置参数,并根据PI 的指令传输数据。
当然,DTP 也可以转入“被动”状态。
服务器FTP 进程,它是和用户FTP 进程一起工作的,它由PI 和DTP 组成。
在开始阶段,标准FTP 命令由用户PI 产生并通过控制连接传送到服务器进程。