FTP端口及主被動詳解

昨天對公司服務器的端口進行了修改,把21端口改了,比如123端口,就這樣用123連接的時候,連接登陸成功,但打不開目錄,怎麼搞的呢,到網上找了下文章,哈哈,終於解決了,連接成功,目錄文件盡在眼前!總結如下:

1、完成一個FTP的傳輸過程不僅僅只需要21一個端口,而是2個端口,21端口只是一個命令端口,其實另外還有一個數據端口,我想這就是有些朋友在內網架設FTP並且在網關上做了21端口的映射之後外網還是不能訪問的原因吧,另外一個數據端口是多少呢?這又牽涉到另外一個問題。

2、FTP具有兩種模式,分別是port模式(也叫主動模式)和pasv模式(也叫被動模式),怎麼來理解這兩種模式呢?我來打個比喻吧,在主動模式下:客戶端給服務器端的21端口發命令說,我要下載什麼什麼,並且還會說我已經打開了自己的某個端口,你就從這裏把東西給我吧,服務器知道後就會通過另外一個數據端口把東西傳給客戶端,這就是主動模式,可以理解爲服務端主動給客戶端傳輸文件;在被動模式下:客戶端給服務器端的21端口發命令說,我要下載什麼什麼,服務器端知道後,就打開一個端口,然後告訴客戶端,我已經打開了某某端口,你自己進去拿吧,於是客戶端就從那個端口進去拿文件了,這就是被動模式,可以理解爲服務端被客戶端拿走了東西,哈哈,可以看懂吧。

在FTP的歷史中,本來只有主動模式的,但是爲什麼又出現了被動模式呢?這又牽涉到另外一個問題了,呵呵~

3、在很久以前(我也不知道多久),地球上還沒有什麼共享上網這種技術,但是後來出現了,所以也就有了下面的問題,大家都知道,共享上網就是很多臺電腦共享一個公網IP去使用internet,再打個比喻吧,某個局域網共享210.33.25.1這個公網IP上網,當一個內網用戶192.168.0.100去訪問外網的FTP服務器時,如果採用主動模式的話,192.168.0.1告訴了FTP服務器我需要某個文件和我打開了x端口之後,由於共享上網的原因,192.168.0.1在出網關的時候自己的IP地址已經被翻譯成了210.33.25.1這個公網IP,所以服務器端收到的消息也就是210.33.25.1需要某個文件並打開了x端口,FTP服務器就會往210.33.25.1的x端口傳數據,這樣當然會連接不成功了,因爲打開x端口的並不是210.33.25.1這個地址,在這種情況下被動模式就有用了,相信大家已經能夠理解被動模式是怎麼個連接法了吧。

好了,說了這麼多,現在可以回到第一個問題了。

在主動模式中,FTP的兩個端口是相對固定的,如果命令端口是x的話,那數據端口就是x-1,也就是說默認情況下,命令端口是21,數據端口就是20;你把命令端口改成了123,那麼數據端口就是122。這樣使用防火牆就很方便了,只要開通這兩個端口就可以了,但是如果客戶端是共享上網的話那豈不是不能正常使用FTP了,這樣還是不行,一定需要被動模式。

在被動模式中就麻煩了些,默認情況下命令端口是21,但是數據端口是隨機的,這個問題又讓我頭痛了一下,還好,我又找到了辦法,因爲被動模式中數據端口的範圍是可以自定義的,在此我以Serv-U 6.1.0.5版爲例,在/Local Server/Settings/Advanced/中。

原創:http://huanhua.blog.51cto.com/965512/545392

 

發佈了6 篇原創文章 · 獲贊 2 · 訪問量 4745
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章