ftpbinary
❶ 怎樣刪除ftp里的一個文件
需要ftp伺服器的管理員才有許可權刪除,具體的刪除方法為:
1、首先,隨意打開一個文件窗口,在上方的地址欄中輸入ftp的網站。
❷ FTP協議中的 Binary和ASCII模式如何實現
你這個代碼根本跟ftp伺服器沒關系吧,就是個傳文件,ftp要有協議的。
用reader和writer是字元流,只能對文本文件,不能對二進制文件,所以得用Stream
FileInputStream fr = new FileInputStream (f);//f是File類型
byte[] buff = new byte[1024];
OutputStream w = s.getOutputStream();
int c;
while((c = r.read(buff))!=-1) {
out.write(buff,0,c);
}
或者用BufferedInputStream和BufferedOutputStream也可以
❸ ftp模式中ASCII傳送與Binary傳送有什麼不同
FTP的傳輸有兩種方式:ASCII傳輸模式和二進制數據傳輸模式。 1.ASCII傳輸方式:假定用戶正在拷貝的文件包含的簡單ASCII碼文本,如果在遠程機器上運行的不是UNIX,當文件傳輸時ftp通常會自動地調整文件的內容以便於把文件解釋成另外那台計算機存...
❹ FTP分為ASCII碼和什麼模式
ftp模式中ASCII傳送與Binary模式
ftp模式中ASCII傳送與Binary傳送有什麼不同
ftp模式中ASCII傳送與Binary傳送有什麼不同
1)ftp中如果選中ASCII形式傳送可執行文件或者壓縮文件(本來應該選擇Binary形式的),會有什麼後
果?
2)
好像ASCII傳送需要發方將本地文本文件轉換成NVT ASCII碼形式,而收方則將NVT ASCII碼再還原
成本地文本文件。而NVT ASCII只有7位,那麼傳送二進制文件時大於#128的byte不是無法傳輸嗎?
但是我平時下載文件(包括可執行文件)都是默認的ASCII形式get下來的,都使用很正常呀,
後來專門用兩種方式下載同一個exe,用fc比較兩個文件,沒有發現任何區別。
3)不過上述下載時c/s都是windows系統,不知道其他OS是否兩種形式有所不同。
那位朋友跟我講講兩者的區別。
FTP 可用多種格式傳輸文件,通常由系統決定,大多數系統(包括UNIX系統)只有兩種模式:文本模式和二進制模式。文本傳輸 器使用ASCII字元,並由回車鍵和換行符分開,而二進制不用轉換或格式化就可傳字元,二進制模式比文本模式更快,並且可以傳輸所有ASCII值,所以系統管理員一般將FTP設置成二進制模式。
一般來說:
如果你用錯誤的模式傳輸你的圖片,你將會無法看到圖片,看到的會是亂碼。
如果你用錯誤模式上傳CGI腳本,那麼就將無法運行你的腳本,會看到類似Server 500 Error的出錯信息。
所以你必須使用正確的模式,圖片和執行文件必須用BINARY模式,CGI腳本和普通HTML文件用ASCII模式上傳.
ASCII和BINARY模式區別:
用HTML 和文本編寫的文件必須用ASCII模式上傳,用BINARY模式上傳會破壞文件,導致文件執行出錯。
BINARY模式用來傳送可執行文件,壓縮文件,和圖片文件。
如果你用ASCII模式傳,會顯示一堆亂碼,你必須重新用BINARY模式傳。
對於第二種情況,是因為有很多ftp伺服器和客戶端軟體能自動識別文件類型,並採取相應的傳輸方式。
ftp是應用層協議,和具體操作系統無關 .
ASCII模式和BINARY模式的區別是回車換行的處理,binary模式不對數據進行任何處理,asci模式將回車換行轉換為本機的回車字元,比如Unix下是\n,Windows下是\r\n,Mac下是\r
ascii模式下會轉換文件
不能說是不同系統對回車換行解釋不同
而是不同的系統有不同的行結束符
unix系統下行結束符是一個位元組,即十六進制的0A
而ms的系統是兩個位元組,即十六進制的0D0A
所以當你用ascii方式從unix的ftp server下載文件時(不管是二進制或者文本文件),每檢測到一個
位元組是0A,就會自動插入一個0D,所以如果你的文件是二進制文件比如可執行文件、壓縮包什麼的,就肯
定不能用了。如果你的文件就是unix下的文本文件,你用ascii模式是正確的,要是誤用了binary模式,
你在windows上看這個文件是沒有換行的,裡面是一個個的黑方塊。
一般來說,我們最好都用binary方式,這樣可以保證不出錯。如果有文本格式轉換的問題,即unix格式
的文本和dos格式的文本之間的轉換,有很多工具可以做的,不要在ftp傳輸的時候冒險,尤其是你如果對
這些東西不是非常清楚的話。
可以使用MIME,把所有的字元,轉換成0~128之間的字元,然後傳送,在接受方再將接收到的字元MIME反向轉換。通常我們發送郵件,就是使用這樣的字元轉換方式。
❺ 用retrbinary進行FTP文件下載,下載的文件大小為0KB,求解
python">defdownload(ftp,filename):
withopen(filename,'wb+')asfp:
try:
ftp.retrbinary("RETR%s"%filename,fp.write,CONST_BUFFER_SIZE)
fp.flush()
exceptftplib.error_perm:
returnFalse
returnTrue
感覺是因為你的文件沒有關閉文件造成的,你試試上面那個。
如果解決了您的問題請採納!
如果未解決請繼續追問
❻ FTP協議的傳輸模式
FTP協議的任務是從一台計算機將文件傳送到另一台計算機,它與這兩台計算機所處的位置、聯接的方式、甚至是是否使用相同的操作系統無關。假設兩台計算機通過ftp協議對話,並且能訪問Internet,
你可以用ftp命令來傳輸文件。每種操作系統使用上有某一些細微差別,但是每種協議基本的命令結構是相同的。
FTP的傳輸有兩種方式:ASCII傳輸模式和二進制數據傳輸模式。 假定用戶正在拷貝的文件包含的簡單ASCII碼文本,如果在遠程機器上運行的是不同的操作系統,當文件傳輸時ftp通常會自動地調整文件的內容以便於把文件解釋成另外那台計算機存儲文本文件的格式。但是常常有這樣的情況,用戶正在傳輸的文件包含的不是文本文件,它們可能是程序,資料庫,字處理文件或者壓縮文件(盡管字處理文件包含的大部分是文本,其中也包含有指示頁尺寸,字型檔等信息的非列印字元)。
在拷貝任何非文本文件之前,用binary 命令告訴ftp逐字拷貝,不要對這些文件進行處理,這也是下面要講的二進制傳輸。 在二進制傳輸中,保存文件的位序,以便原始和拷貝的是逐位一一對應的。即使目的地機器上包含位序列的文件是沒意義的。例如,macintosh以二進制方式傳送可執行文件到Windows系統,在對方系統上,此文件不能執行。
如果你在ASCII方式下傳輸二進制文件,即使不需要也仍會轉譯。這會使傳輸稍微變慢 ,也會損壞數據,使文件變得不能用。(在大多數計算機上,ASCII方式一般假設每一字元的第一有效位無意義,因為ASCII字元組合不使用它。如果你傳輸二進制文件,所有的位都是重要的。)如果你知道這兩台機器是同樣的,則二進制方式對文本文件和數據文件都是有效的。
❼ 什麼是binary文件
binary 是二進制文件。計算機上所有的文件都是二進制文件,對,所有的都是二進制。
那為什麼有得能打開?有的不知道怎麼打開?
因為你的當前系統知道那些能被打開的文件的「文件格式」。很多格式是故意公開讓所有的軟體都方便打開,比如文本文件、pdf、avi這些。
不能打開的二進制文件怎麼打開?
知道格式就能打開。
除了軟體允許的開啟方式和已知的一些公開格式,其餘二進制文件怎麼知道格式?
要麼,文件的生成者提供格式的技術文檔給你,而且有人替你寫代碼打開。
要麼,找最最高手不惜成本的替你分析出格式並寫出閱讀軟體。這要求對數據結構和對數據序列化方式的見多識廣。
要麼,別管了,開發者之所以給二進制文件就是不想讓人去修改數據結構
❽ FTP傳輸協議命令中type i 和type a的區別是什麼
ftp傳輸中,傳輸模式有Binary和Ascii兩種方式。
Binary按照二進制形式傳輸,傳輸前後的文件是一樣的。
Ascii是按照文本形式傳輸,在unix和windows下,文本的行結束字元不一樣,一個是'\n',一個是'\n\r'。Ascii傳輸的時候,自動轉換了行結束字元。
通常情況下,最好按照Binary來傳輸。
你使用的type
i和type
a應該是簡寫,我的ftp中沒有。
通常使用的指令是binary或者type
binary,ascii或者type
ascii。
❾ FTP的傳輸有兩種方式
FTP的傳輸有兩種方式:ASCII傳輸模式和二進制數據傳輸模式。
1.ASCII傳輸方式:假定用戶正在拷貝的文件包含的簡單ASCII碼文本,如果在遠程機器上運行的不是UNIX,當文件傳輸時ftp通常會自動地調整文件的內容以便於把文件解釋成另外那台計算機存儲文本文件的格式。
但是常常有這樣的情況,用戶正在傳輸的文件包含的不是文本文件,它們可能是程序,資料庫,字處理文件或者壓縮文件(盡管字處理文件包含的大部分是文本,其中也包含有指示頁尺寸,字型檔等信息的非列印字元)。在拷貝任何非文本文件之前,用binary 命令告訴ftp逐字拷貝,不要對這些文件進行處理,這也是下面要講的二進制傳輸。
2.二進制傳輸模式:在二進制傳輸中,保存文件的位序,以便原始和拷貝的是逐位一一對應的。即使目的地機器上包含位序列的文件是沒意義的。例如,macintosh以二進制方式傳送可執行文件到Windows系統,在對方系統上,此文件不能執行。
如果你在ASCII方式下傳輸二進制文件,即使不需要也仍會轉譯。這會使傳輸稍微變慢 ,也會損壞數據,使文件變得不能用。(在大多數計算機上,ASCII方式一般假設每一字元的第一有效位無意義,因為ASCII字元組合不使用它。如果你傳輸二進制文件,所有的位都是重要的。)如果你知道這兩台機器是同樣的,則二進制方式對文本文件和數據文件都是有效的。
5. FTP的工作方式
FTP支持兩種模式,一種方式叫做Standard (也就是 PORT方式,主動方式),一種是 Passive (也就是PASV,被動方式)。 Standard模式 FTP的客戶端發送 PORT 命令到FTP伺服器。Passive模式FTP的客戶端發送 PASV命令到 FTP Server。
下面介紹一個這兩種方式的工作原理:
Port模式FTP 客戶端首先和FTP伺服器的TCP 21埠建立連接,通過這個通道發送命令,客戶端需要接收數據的時候在這個通道上發送PORT命令。 PORT命令包含了客戶端用什麼埠接收數據。在傳送數據的時候,伺服器端通過自己的TCP 20埠連接至客戶端的指定埠發送數據。 FTP server必須和客戶端建立一個新的連接用來傳送數據。
Passive模式在建立控制通道的時候和Standard模式類似,但建立連接後發送的不是Port命令,而是Pasv命令。FTP伺服器收到Pasv命令後,隨機打開一個高端埠(埠號大於1024)並且通知客戶端在這個埠上傳送數據的請求,客戶端連接FTP伺服器此埠,然後FTP伺服器將通過這個埠進行數據的傳送,這個時候FTP server不再需要建立一個新的和客戶端之間的連接。
很多防火牆在設置的時候都是不允許接受外部發起的連接的,所以許多位於防火牆後或內網的FTP伺服器不支持PASV模式,因為客戶端無法穿過防火牆打開FTP伺服器的高端埠;而許多內網的客戶端不能用PORT模式登陸FTP伺服器,因為從伺服器的TCP 20無法和內部網路的客戶端建立一個新的連接,造成無法工作。
❿ linux怎麼修改ftp binary
ftp的binary的設置需要自己執行binary命令進行設置。具體
ftp
打開ftp交互窗口後。
binary
執行即可。