文件傳輸協議FTP(File Transfer Protocol)是因特網中使用最廣泛的文件傳輸協議。FTP使用交互式的訪問,允許客戶指定文件的類型和格式(如指明是否使用ASCII碼),并允許文件具有存取權限(如訪問文件的用戶必須經過授權,并輸入有效的口令)。
文件傳輸協議有基于TCP的FTP和基于UDP的簡單文件傳輸協議TFTP,它們都是文件共享協議中的一大類,即複制整個文件,其特點是:若要存取一個文件,就必須先獲得一個本地的文件副本。如果要修改文件,隻能對文件的副本進行修改,然後再将修改後的文件傳回到原節點。
1 FTP基本工作原理FTP屏蔽了各計算機系統的細節,因而适合在異構網絡中任意計算機之間傳送文件。FTP隻提供文件傳送的一些基本服務,它使用TCP可靠地運輸服務,FTP主要功能是減小或消除在不同系統下處理文件的不兼容性。
FTP使用客戶端-服務器模型,一個FTP服務器進程可以為多個客戶進程提供服務。FTP服務器有兩大部分組成:一個主進程,負責接受新的請求;還有若幹從屬進程,負責處理單個請求。主進程工作步驟
FTP工作時情況
FTP控制連接在整個會話期間都保持打開,隻用來發送連接/傳送請求。當客戶進程向服務器發送連接請求時,尋找連接服務器進程的熟知端口21,同時還要告訴服務器進程自己的另一個端口号碼,用于建立數據傳送連接。接着,服務器進程用自己傳送數據的熟知端口20與客戶進程所提供的端口号碼建立數據傳送連接,FTP使用了2個不同的端口号,所以數據連接和控制連接不會混亂。
1.1 FTP數據表示
FTP協議規定了控制協議傳送與存儲的多種選擇,在以下4個方面必須做出一個選擇。
1.2 FTP命令和應答
命令和應答在客戶和服務器的控制連接上以 NVT ASCII碼形式傳送。這就要求在每行結尾都要返回C R、 L F對(也就是每個命令或每個應答)。這些命令都是3或4個字節的大寫ASCII字符,其中一些帶選項參數。從客戶向服務器發送的FTP命令超過30種。下圖是比較常用的幾種命令:
應答都是A S C I I碼形式的3位數字,并跟有報文選項。其原因是軟件系統需要根據數字代碼來決定如何應答,而選項串是面向人工處理的。由于客戶通常都要輸出數字應答和報文串,一個可交互的用戶可以通過閱讀報文串(而不必記憶所有數字回答代碼的含義)來确定應答的含義。
2 FTP工作模式FTP有兩種工作模式,分别是主動模式(PORT)和被動模式(PASV)兩種模式,這兩種模式是按照FTP服務器的“角度”來說的,更通俗一點說就是:在傳輸數據時,如果是服務器主動連接客戶端,那就是主動模式;如果是客戶端主動連接服務器,那就是被動模式。關于主動模式和被動模式更具體的講解請點擊:圖解FTP的主動模式與被動模式以及客戶端設置。
3 關于FTP經典的問題3.1 如何知道FTP傳送一個文件結束?
這個問題比較經典,也是一次面試被問到的問題。前面說過,通用傳輸方式是流方式,并且文件的結尾是以關閉數據連接為标志,這意味着對每一個文件傳輸或目錄列表來說都要建立一個全新的數據連接。其一般過程如下:
圖27- 4給出了第 3步執行時的連接狀态。假設客戶用于控制連接的臨時端口是 11 7 3,客戶用于數據連接的臨時端口是 11 7 4。客戶發出的命令是PORT命令,其參數是6個ASCII中的十進制數字,它們之間由逗點隔開。前面 4個數字指明客戶上的 I P地址,服務器将向它發出主動打開(本例中是 140.252.13.34),而後兩位指明16 bit端口地址。由于16 bit端口地址是從這兩個數字中得來,所以其值在本例中就是 4×256 150=1174。
圖27-5給出了服務器向客戶所在數據連接端發布主動打開時的連接狀态。服務器的端點是端口2 0。
服務器總是執行數據連接的主動打開。通常服務器也執行數據連接的主動關閉,除非當客戶向服務器發送流形式的文件時,需要客戶來關閉連接(它給服務器一個文件結束的通知)。
參考資料:
1、《計算機網絡》FTP協議章節
2、《TCP/IP協議詳解》FTP協議章節
3、圖解FTP的主動模式與被動模式以及客戶端設置
,更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!