當前位置:首頁 » 文件傳輸 » 為什麼說FTP是帶外控制信息
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

為什麼說FTP是帶外控制信息

發布時間: 2022-05-01 23:40:10

⑴ FTP是什麼意思FTP軟體又是什麼東西/

FTP是一種上傳和下載用的軟體。用FTP把自己電腦里的東西,傳到網上的免費空間,它也可以用來下載文件,只要有地址。

FTP定義如下:

FTP(File Transfer Protocal),是用於Internet上的控制文件的雙向傳輸的協議。同時,它也是一個應用程序。用戶可以通過它把自己的PC機與世界各地所有運行FTP協議的伺服器相連,訪問伺服器上的大量程序和信息。

傳輸文件的一般步驟如下:

1在本地電腦上登陸到國際互聯網,

2搜索有文件共享主機或者個人電腦(一般有專門的FTP伺服器網站上公布的,上面有進入該主機或個人電腦的名稱,口令和路徑)

3當與遠程主機或者對方的個人電腦建立連接後,用對方提供的用戶名和口令登陸到該主機或對方的個人電腦.

4在遠程主機或對方的個人電腦登陸成功後,就可以上傳你想跟別人分享的東東或者下載別人授權共享的東東(這里的東東是指能放到電腦里去又能在顯示屏上看到的東東)

5完成工作後關閉FTP下載軟體,切斷連接.

為了實現文件傳輸,用戶還要運行專門的文件傳輸程序,比如網際快車就有這方面的功能,其它還有很多專門的FTP傳輸軟體,各有各的特色.

FTP(File Transfer Protocol)是文件傳輸協議的簡稱。

FTP的作用

正如其名所示:FTP的主要作用,就是讓用戶連接上一個遠程計算機(這些計算機上運行著FTP伺服器程序)察看遠程計算機有哪些文件,然後把文件從遠程計算機上拷到本地計算機,或把本地計算機的文件送到遠程計算機去。

FTP工作原理

拿下傳文件為例,當你啟動FTP從遠程計算機拷貝文件時,你事實上啟動了兩個程序:一個本地機上的FTP客戶程序:它向FTP伺服器提出拷貝文件的請求。另一個是啟動在遠程計算機的上的FTP伺服器程序,它響應你的請求把你指定的文件傳送到你的計算機中。FTP採用「客戶機/伺服器」方式,用戶端要在自己的本地計算機上安裝FTP客戶程序。FTP客戶程序有字元界面和圖形界面兩種。字元界面的FTP的命令復雜、繁多。圖形界面的FTP客戶程序,操作上要簡潔方便的多。

簡單地說,支持FTP協議的伺服器就是FTP伺服器,下面介紹一下什麼是FTP協議(文件傳輸協議)

一般來說,用戶聯網的首要目的就是實現信息共享,文件傳輸是信息共享非常重要的一個內容之一。Internet上早期實現傳輸文件,並不是一件容易的事,我們知道 Internet是一個非常復雜的計算機環境,有PC,有工作站,有MAC,有大型機,據統計連接在Internet上的計算機已有上千萬台,而這些計算機可能運行不同的操作系統,有運行Unix的伺服器,也有運行Dos、Windows的PC機和運行MacOS的蘋果機等等,而各種操作系統之間的文件交流問題,需要建立一個統一的文件傳輸協議,這就是所謂的FTP。基於不同的操作系統有不同的FTP應用程序,而所有這些應用程序都遵守同一種協議,這樣用戶就可以把自己的文件傳送給別人,或者從其它的用戶環境中獲得文件。

與大多數Internet服務一樣,FTP也是一個客戶機/伺服器系統。用戶通過一個支持FTP協議的客戶機程序,連接到在遠程主機上的FTP伺服器程序。用戶通過客戶機程序向伺服器程序發出命令,伺服器程序執行用戶所發出的命令,並將執行的結果返回到客戶機。比如說,用戶發出一條命令,要求伺服器向用戶傳送某一個文件的一份拷貝,伺服器會響應這條命令,將指定文件送至用戶的機器上。客戶機程序代表用戶接收到這個文件,將其存放在用戶目錄中。

在FTP的使用當中,用戶經常遇到兩個概念:"下載"(Download)和"上載"(Upload)。"下載"文件就是從遠程主機拷貝文件至自己的計算機上;"上載"文件就是將文件從自己的計算機中拷貝至遠程主機上。用Internet語言來說,用戶可通過客戶機程序向(從)遠程主機上載(下載)文件。

使用FTP時必須首先登錄,在遠程主機上獲得相應的許可權以後,方可上載或下載文件。也就是說,要想同哪一台計算機傳送文件,就必須具有哪一台計算機的適當授權。換言之,除非有用戶ID和口令,否則便無法傳送文件。這種情況違背了Internet的開放性,Internet上的FTP主機何止千萬,不可能要求每個用戶在每一台主機上都擁有帳號。匿名FTP就是為解決這個問題而產生的。

匿名FTP是這樣一種機制,用戶可通過它連接到遠程主機上,並從其下載文件,而無需成為其注冊用戶。系統管理員建立了一個特殊的用戶ID,名為anonymous, Internet上的任何人在任何地方都可使用該用戶ID。

通過FTP程序連接匿名FTP主機的方式同連接普通FTP主機的方式差不多,只是在要求提供用戶標識ID時必須輸入anonymous,該用戶ID的口令可以是任意的字元串。習慣上,用自己的E-mail地址作為口令,使系統維護程序能夠記錄下來誰在存取這些文件。

值得注意的是,匿名FTP不適用於所有Internet主機,它只適用於那些提供了這項服務的主機。

當遠程主機提供匿名FTP服務時,會指定某些目錄向公眾開放,允許匿名存取。系統中的其餘目錄則處於隱匿狀態。作為一種安全措施,大多數匿名FTP主機都允許用戶從其下載文件,而不允許用戶向其上載文件,也就是說,用戶可將匿名FTP主機上的所有文件全部拷貝到自己的機器上,但不能將自己機器上的任何一個文件拷貝至匿名FTP主機上。即使有些匿名FTP主機確實允許用戶上載文件,用戶也只能將文件上載至某一指定上載目錄中。隨後,系統管理員會去檢查這些文件,他會將這些文件移至另一個公共下載目錄中,供其他用戶下載,利用這種方式,遠程主機的用戶得到了保護,避免了有人上載有問題的文件,如帶病毒的文件。

作為一個Internet用戶,可通過FTP在任何兩台Internet主機之間拷貝文件。但是,實際上大多數人只有一個Internet帳戶,FTP主要用於下載公共文件,例如共享軟體、各公司技術支持文件等。 Internet上有成千上萬台匿名FTP主機,這些主機上存放著數不清的文件,供用戶免費拷貝。實際上,幾乎所有類型的信息,所有類型的計算機程序都可以在Internet上找到。這是Internet吸引我們的重要原因之一。

匿名FTP使用戶有機會存取到世界上最大的信息庫,這個信息庫是日積月累起來的,並且還在不斷增長,永不關閉,涉及到幾乎所有主題。而且,這一切是免費的。

匿名FTP是Internet網上發布軟體的常用方法。Internet之所以能延續到今天,是因為人們使用通過標准協議提供標准服務的程序。像這樣的程序,有許多就是通過匿名FTP發布的,任何人都可以存取它們。

Internet中的有數目巨大的匿名FTP主機以及更多的文件,那麼到底怎樣才能知道某一特定文件位於哪個匿名FTP主機上的那個目錄中呢?這正是Archie伺服器所要完成的工作。Archie將自動在FTP主機中進行搜索,構造一個包含全部文件目錄信息的資料庫,使你可以直接找到所需文件的位置信息。

⑵ 為什麼說ftp是帶外傳送控制信息

FTP
的伺服器進程由兩大部分組成:一個主進程,負責接受新的請求;另外有若干個從屬進程,負責處理單個請求。
主進程的工作步驟:
1、打開熟知埠(埠號為
21),使客戶進程能夠連接上。
2、等待客戶進程發出連接請求。
3、啟動從屬進程來處理客戶進程發來的請求。從屬進程對客戶進程的請求處理完畢後即終止,但從屬進程在運行期間根據需要還可能創建其他一些子進程。
4、回到等待狀態,繼續接受其他客戶進程發來的請求。主進程與從屬進程的處理是並發地進行。
FTP使用兩個TCP連接。
控制連接在整個會話期間一直保持打開,FTP
客戶發出的傳送請求通過控制連接發送給伺服器端的控制進程,但控制連接不用來傳送文件。
實際用於傳輸文件的是「數據連接」。伺服器端的控制進程在接收到
FTP
客戶發送來的文件傳輸請求後就創建「數據傳送進程」和「數據連接」,用來連接客戶端和伺服器端的數據傳送進程。
數據傳送進程實際完成文件的傳送,在傳送完畢後關閉「數據傳送連接」並結束運行。

⑶ 大家好 我問一個問題 就是什麼是FTP 他們告訴我的話是『FTP地址...........』 這個FTP是什麼意思

FTP文件傳送協議(File Transfer Protocol,簡稱FTP),是一個用於從一台主機到另送文件的協議。該協議的歷史可追溯到1971年(當時網際網路尚處於實驗之中),不過至今仍然極為流行。FTP在RFC 959中具體說明。下圖是它提供的服務的概貌。

圖1 FTP在本地和遠程文件系統之間傳輸文件

在一個典型的FTP會話中,用戶坐在本地主機前,想把文件傳送到一台遠程主機或把它們從一台遠程主機傳送來。該用戶必須提供一個用戶名—口令對才能訪問遠程賬號。給出這些身份認證信息後,它就可以在本地文件系統和遠程文件系統之間傳送文件了。如圖中所示,用戶通過一個FTP用戶代理與FTP交互。他首先提供一個遠程主機的主機名,這使得本地主機中的FTP客戶進程建立一個與遠程主機中的FTP伺服器進程之間的連接。用戶接著提供用戶名和口令,這些信息將作為FTP命令參數經由TCP連接傳送到伺服器。伺服器批准之後,該用戶就在本地文件系統和遠程文件系統之間拷貝文件。

HTTP和FTP都是文件傳送協議,它們有許多共同的特徵,譬如說都運行在TCP之上。不過這兩個應用層協議之間存在重要的差別。最重要的差別是FTP使用兩個並行的TCP連接來傳送文下一節件,一個是控制連接,一個是數據連接。控制連接用於在客戶主機和伺服器主機之間發送控制信息,例如用戶名和口令、改變遠程目錄的命令、取來或放迴文件的命令。數據連接用於真正發送文件。既然TCP使用一個獨立的控制連接,我們說FTP在帶外(out-of-band)發送控制信息的。另外,用於控制音頻和視頻等持續媒體數據之傳送的RTSP協議也是在帶外發送控制信息的。HTTP中,同一個TCP連接既用於承載請求和響應頭部,也用於承裁所傳送的文件,因此我們說HTTP在帶內(in-band)發送控制信息。下一篇文章將討論的用於電子郵件的主要協議SMTP也在帶內發送控制信息。圖2展示了FTP的控制連接和數據連接。

圖2

當用戶啟動與遠程主機間的一個FTP會話時,FTP客戶首先發起建立一個與FTP伺服器埠號21之間的控制TCP連接,然後經由該控制連接把用戶名和口令發送給伺服器。客戶還經由該控制連接把本地臨時分配的數據埠告知伺服器,以便伺服器發起建立一個從伺服器埠號20到客戶指定埠之間的數據TCP連接;為便於繞過防火牆,較新的FTP版本允許客戶告知伺服器改由客戶來發起建立到伺服器埠號20的數據TCP連接。用戶執行的一些命令也由客戶經由控制連接發送給伺服器,例如改變遠程目錄的命令。當用戶每次請求傳送文件時(不論哪個方向),FTP將在伺服器埠號20上打開一個數據TCP連接(其發起端既可能是伺服器,也可能是客戶)。在數據連接上傳送完本次請求需傳送的文件之後,有可能關閉數據連接,到再有文件傳送請求時重新打開。因此在FTP中,控制連接在整個用戶會話期間一直打開著,而數據連接則有可能為每次文件傳送請求重新打開一次(即數據連接是非持久的)。

在整個會話期間,FTP伺服器必須維護關於用戶的狀態。具體地說,伺服器必須把控制連接與特定的用戶關聯起來,必須隨用戶在遠程目錄樹中的游動跟蹤其當前目錄。為每個活躍的用戶會話保持這些狀態信息極大地限制了FTP能夠同時維護的會話數。無狀態的HTTP卻不必維護任何用戶狀態信息。

FTP命令和應答

現在討論幾個較為常用的FTP命令。從客戶到伺服器的命令和從伺服器到客戶的應答都是以7位ASCII碼格式經由控制連接傳送的,因此跟HTTP請求消息一樣.FTP命令也是直觀可讀的。用於分割相繼的命令或應答的是一個回車符和一個換行符。每個命令由4個大寫的ASCB字元構成,有些命令帶有可選的參數。下面給出的是一些較為常見的命令;●USER username:用於向伺服器發送用戶名。

●PASS passwod:用於伺服器發送口令。

●LIST:用於請求伺服器發回當前遠程目錄下所有文件的一個清單。該清單是通過數據連接而不是控制連接發送過來的。

●RETR filename:用於獲取遠程主機當前目錄下的一個文件,與用戶代理中的get命令相對應。

●STOR filename:用於存放遠程主機當前目錄下的一個文件,與用戶代理中的put命令相對應。

從客戶經由控制連接發送到伺服器的FTP命令和用戶向用戶代理發出的命令之間一般存在一一對應關系。每個命令之後跟隨的是從伺服器發送到客戶的應答。FTP應答是一個3位數值,可能後跟一個可選的消息。這與HTTP響應消息中的狀態碼和原因短語在結構上是類似的;HTTP的發明者們有意在HTTP響應消息中引入了這個類似性。下面列出了一些典型的應答以及可能後跟的消息。

●331 Username OK,password required

●125 Data connection already open,tranfer starting

●425 Car't open data connection

●452 Error writing

有興趣更多地了解FD命令和應答的讀者可以閱讀RFC 959。

下面是採用LEAPFTP客戶端登錄一個FTP伺服器的對話實錄,從中可以看到FTP客戶端和伺服器端的會話過程。

Connecting to xxx.xxx.xxx.xxx, Port 21 (#1)

Connected. Waiting for response.

220 Microsoft FTP Service

USER username

331 Password required for username.

PASS xxxxxx

230 User 9878cn logged in.

SYST

215 Windows_NT

PWD

257 "/mydir" is current directory.

TYPE A

200 Type set to A.

PORT 192,168,xxx,xx,9,198

200 PORT command successful.

LIST

150 Opening ASCII mode data connection for /bin/ls.

226 Transfer complete.

Transfer done: 125 bytes in 0.016 secs (7.81 k/sec)

QUIT

⑷ 為什麼說ftp是帶外傳送控制信息

由於FTP使用了一個分離的控制連接,因此FTP的控制信息是帶外傳送的。

⑸ 簡述FTP的工作原理

FTP的工作原理:FTP 採用 Internet 標准文件傳輸協議 FTP 的用戶界面, 向用戶提供了一組用來管理計算機之間文件傳輸的應用程序。

開發任何基於 FTP 的客戶端軟體都必須遵循 FTP 的工作原理,FTP 的獨特的優勢同時也是與其它客戶伺服器程序最大的不同點就在於它在兩台通信的主機之間使用了兩條 TCP 連接,一條是數據連接,用於數據傳送;

另一條是控制連接,用於傳送控制信息(命令和響應),這種將命令和數據分開傳送的思想大大提高了 FTP 的效率,而其它客戶伺服器應用程序只有一條 TCP 連接。

(5)為什麼說FTP是帶外控制信息擴展閱讀:

FTP 的目標是提高文件的共享性,提供非直接使用遠程計算機,使存儲介質對用戶透明和可靠高效地傳送數據。它能操作任何類型的文件而不需要進一步處理,就像MIME或Unicode一樣。

但是,FTP有著極高的延時,這意味著,從開始請求到第一次接收需求數據之間的時間,會非常長;並且不時的必須執行一些冗長的登錄進程。

FTP 在網際網路網路上歷史是最悠久的網路工具,從 1971 年由 A KBHUSHAN 提出第一個 FTP 的RFC(RFC114),FTP 憑借其獨特的優勢一直都是網際網路中最重要、最廣泛的服務之一。

⑹ HTTP協議和FTP協議的相同點和不同點

最大的區別是spi是4線(時鍾,兩個數據線,片選線)或者3線(時鍾,兩個數據線)的,i2c是兩線的(時鍾,一個數據線)。一般spi的速度比i2c快很多,因為它有兩個數據線的所以可以實現全雙工通訊,而i2c因為收發共用一根數據線,所以只能是半雙工的。

⑺ 為什麼說ftp在"帶外"發送控制信息

其實ftp使用tcp的兩個埠20/21分別跑數據和控制消息

⑻ HTTP和FTP的共同點以及不同點

相同點:都基於TCP協議,都在客戶、伺服器模型的應用層協議之上
不同點:HTTP是無狀態的協議,而FTP是有狀態的協議;
HTTP是帶內控制的,FTP是帶外控制的;
FTP一般需要輸入帳戶和口令來確認信息

⑼ 為什麼說ftp是帶外傳送控制信息

FTP 的伺服器進程由兩大部分組成:一個主進程,負責接受新的請求;另外有若干個從屬進程,負責處理單個請求。
主進程的工作步驟:
1、打開熟知埠(埠號為 21),使客戶進程能夠連接上。
2、等待客戶進程發出連接請求。
3、啟動從屬進程來處理客戶進程發來的請求。從屬進程對客戶進程的請求處理完畢後即終止,但從屬進程在運行期間根據需要還可能創建其他一些子進程。
4、回到等待狀態,繼續接受其他客戶進程發來的請求。主進程與從屬進程的處理是並發地進行。
FTP使用兩個TCP連接。
控制連接在整個會話期間一直保持打開,FTP 客戶發出的傳送請求通過控制連接發送給伺服器端的控制進程,但控制連接不用來傳送文件。
實際用於傳輸文件的是「數據連接」。伺服器端的控制進程在接收到 FTP 客戶發送來的文件傳輸請求後就創建「數據傳送進程」和「數據連接」,用來連接客戶端和伺服器端的數據傳送進程。
數據傳送進程實際完成文件的傳送,在傳送完畢後關閉「數據傳送連接」並結束運行。

⑽ FTP是什麼

FTP(File Transfer Protocol,文件傳輸協議) 是 TCP/IP 協議組中的協議之一。FTP協議包括兩個組成部分,其一為FTP伺服器,其二為FTP客戶端。

其中FTP伺服器用來存儲文件,用戶可以使用FTP客戶端通過FTP協議訪問位於FTP伺服器上的資源。在開發網站的時候,通常利用FTP協議把網頁或程序傳到Web伺服器上。此外,由於FTP傳輸效率非常高,在網路上傳輸大的文件時,一般也採用該協議。



(10)為什麼說FTP是帶外控制信息擴展閱讀:

同大多數Internet服務一樣,FTP也是一個客戶/伺服器系統。用戶通過一個客戶機程序連接至在遠程計算機上運行的伺服器程序。依照 FTP 協議提供服務,進行文件傳送的計算機就是 FTP伺服器,而連接FTP伺服器,遵循FTP協議與伺服器傳送文件的電腦就是FTP客戶端。

用戶要連上FTP 伺服器,就要用到 FTP 的客戶端軟體,通常 Windows自帶「ftp」命令,這是一個命令行的 FTP客戶程序,另外常用的 FTP 客戶程序還有FileZilla、 CuteFTP、Ws_FTP、Flashfxp、LeapFTP、流星雨-貓眼等。