python一秒搭建FTP服務(wù)器
(1) 主動(dòng)模式:客戶端首先從任意的非特殊端口n(大于1023的端口,也是客戶端的命令端口)連接FTP服務(wù)器的命令端口(默認(rèn)是21),向服務(wù)器發(fā)出命令 PORT n+1,告訴服務(wù)器自己使用n+1端口作為數(shù)據(jù)端口進(jìn)行數(shù)據(jù)傳輸,然后在n+1端口監(jiān)聽。服務(wù)器收到PORT n+1后向客戶端返回一個(gè)“ACK”,然后服務(wù)器從它自己的數(shù)據(jù)端口(20)到 客戶端先前指定的數(shù)據(jù)端口(n+1端口)的連接,最后客戶端向服務(wù)器返回一個(gè)“ACK”。
(2)被動(dòng)模式:為了解決服務(wù)器發(fā)起到客戶端的連接問(wèn)題,開發(fā)了被動(dòng)FTP,或者叫做PASV,當(dāng)客戶端通知服務(wù)器處于被動(dòng)模式時(shí)才啟用。在被動(dòng)模式下,命令連接和數(shù)據(jù)連接都是有客戶端發(fā)起。當(dāng)開啟一個(gè)FTP連接時(shí),客戶端打開兩個(gè)非特權(quán)的任意端口(大于1023)。第一個(gè)端口連接服務(wù)器的21端口,但是與主動(dòng)方式不同,客戶端不會(huì)提交PORT命令并允許服務(wù)器來(lái)回連接數(shù)據(jù)端口,而是提交PASV命令。這樣做的結(jié)果就是服務(wù)器會(huì)開啟任意一個(gè)非特權(quán)端口,并且發(fā)送PORT p命令給客戶端,然后客戶端發(fā)起從本地端口 n+1 到 服務(wù)器端口p 的連接來(lái)傳輸數(shù)據(jù)
總結(jié):主動(dòng)模式有利于對(duì)FTP服務(wù)器的管理,但是不利于對(duì)客戶端的管理。因?yàn)镕TP服務(wù)器企圖和客戶端的高位隨機(jī)端口建立連接,而這個(gè)端口很有可能會(huì)被客戶端的防火墻阻塞掉。被動(dòng)模式相反。
二、利用python搭建FTP服務(wù)器python搭建FTP需要利用到pyftpdlib模塊
1.安裝 pyftpdlib 模塊C:UsersLTP> pip3 install pyftpdlibC:UsersLTP> python3 -m pyftpdlib -p 21
2.找到pyftpdlib模塊源文件所在目錄
C:UsersLTP> python3……>>> import pyftpdlib>>> pyftpdlib.__path__[’/usr/local/python3/lib/python3.7/site-packages/pyftpdlib’]
3.到 pyftpdlib目錄下
發(fā)現(xiàn) filesystems.py 和 handlers.py 兩個(gè)文件,先執(zhí)行備份
C:UsersLTP> dir E:PycharmProjectsuntitledproject01venvLibsite-packagespyftpdlib2021/05/15 17:50 <DIR> .2021/05/15 17:50 <DIR> ..2017/12/30 16:44 35,246 authorizers.py2021/05/15 17:49 24,798 filesystems - 副本.py2021/05/15 17:49 24,798 filesystems.py2019/10/24 16:26 144,635 handlers - 副本.py2019/10/24 16:26 144,635 handlers.py2017/12/30 16:44 36,769 ioloop.py2019/10/24 16:26 5,823 log.py2019/10/24 16:26 3,844 prefork.py2019/10/24 16:26 21,658 servers.py2021/05/15 17:45 <DIR> test2019/10/24 16:26 774 _compat.py2019/10/24 16:28 2,845 __init__.py2018/04/26 18:41 4,879 __main__.py2021/05/15 17:46 <DIR> __pycache__ 12 個(gè)文件450,704 字節(jié) 4 個(gè)目錄 44,605,644,800 可用字節(jié)# 備份 filesystems.py 和 handlers.py# 修改filesystems.py文件# 將原本的'utf-8'修改成'gbk'(windows支持的gbk類型的bytes)503 yield line.encode(’gbk’, self.cmd_channel.unicode_errors# 修改 handlers.py 文件# 將原本的'utf-8'修改成'gbk'(windows支持的gbk類型的bytes)1413 return bytes.decode(’gbk’, self.unicode_errors)
4. 編寫并運(yùn)行FTP代碼
# 該腳本程序是運(yùn)行在windows上的ftp,運(yùn)行前需要安裝pyftpdlib模塊, pip3 install pyftpdlib# 修改filesystems.py文件,將503 行的 'utf-8'修改成'gbk'(windows支持的gbk類型的bytes)即 yield line.encode(’gbk’, self.cmd_channel.unicode_errors# 修改 handlers.py 文件,將1413行的'utf-8'修改成'gbk'(windows支持的gbk類型的bytes)即 return bytes.decode(’gbk’, self.unicode_errors)from pyftpdlib.authorizers import DummyAuthorizerfrom pyftpdlib.handlers import FTPHandler,ThrottledDTPHandlerfrom pyftpdlib.servers import FTPServerfrom pyftpdlib.log import LogFormatterimport logging# 1.記錄日志輸出到文件和終端logger = logging.getLogger(’FTP-LOG’)logger.setLevel(logging.DEBUG)cs = logging.StreamHandler()cs.setLevel(logging.INFO)fs = logging.FileHandler(filename=’test.log’, mode=’a’, encoding=’utf-8’)fs.setLevel(logging.DEBUG)formatter = logging.Formatter(’[%(asctime)s] %(name)s - %(levelname)s : %(message)s’)cs.setFormatter(formatter)fs.setFormatter(formatter)logger.addHandler(cs)logger.addHandler(fs)# 2.實(shí)例化虛擬用戶,這是FTP的首要條件authorizer = DummyAuthorizer()# 3.添加用戶權(quán)限和路徑,括號(hào)內(nèi)的參數(shù)是(用戶名、密碼、用戶目錄、權(quán)限),可以為不同的用戶添加不同的目錄和權(quán)限authorizer.add_user(’user’, ’123456’, 'd:/', perm='elradfmw')# 4.添加匿名用戶,只需要路徑authorizer.add_anonymous('d:/')# 5.初始化ftp句柄handler = FTPHandlerhandler.authorizer = authorizer# 6.添加被動(dòng)端口范圍handler.passive_ports = range(2000,20033)# 7.上傳下載的速度設(shè)置dtp_handler = ThrottledDTPHandlerdtp_handler.read_limit = 300 * 1024 # 300 kb/sdtp_handler.write_limit = 300 * 1024 # 300 kb/shandler.dtp_handler = dtp_handler# 8.監(jiān)聽ip和端口 , linux里需要root用戶才能使用21端口server = FTPServer((’0.0.0.0’, 21), handler)# 9.最大連接數(shù)server.max_cons = 150server.max_cons_per_ip = 15# 10.開始服務(wù),自帶打印日志信息server.serve_forever()
authorizer.add_user(‘user’, ‘123456’, “d:/”, perm=“elradfmw”)中perm權(quán)限參數(shù)的含義:1、讀權(quán)限:
e :改變文件目錄l :列出文件r :從服務(wù)器接收文件2、寫權(quán)限
a :文件上傳d :刪除文件f :文件重命名m :創(chuàng)建文件w :寫權(quán)限M:文件傳輸模式(通過(guò)FTP設(shè)置文件權(quán)限)5.使用CMD登入FTP驗(yàn)證使用正常,認(rèn)證正常
可以用于文件的上傳下載
[root@localhost python]# vim ftp.py #!/bin/env python3# -*- coding: utf-8 -*-# Time: 2021-5-15 21:08# Description: FTP CLIENT# File Name: ftp.py# FTP客戶端from ftplib import FTP# 1.登入ftpftp = FTP(host=’192.168.0.108’, user=’user’, passwd=’123456’)# 設(shè)置編碼方式,由于在windows系統(tǒng),設(shè)置編碼方式為gbk’ftp.encoding = ’gbk’# 切換目錄ftp.cwd(’test’)# 列出文件夾內(nèi)容ftp.retrlines(’LIST’) # 或者ftp.dir()# 下載文件 node.txtftp.retrbinary(’RETR node.txt’, open(’node.txt’, ’wb’).write)# 上傳文件ftpserver.pyftp.storbinary(’STOR ftpserver.py’, open(’ftpserver.py’, ’rb’))# 查看目錄下文件詳情for file in ftp.mlsd(path=’/test’): print(file)
執(zhí)行結(jié)果:
[root@localhost python]# ./ftp.py # 列出了test文件夾中的內(nèi)容-rw-rw-rw- 1 owner group 1661 May 15 14:19 ftpserver.py-rw-rw-rw- 1 owner group 12 May 15 14:14 node.txt# 查看到了目錄下文件的詳情(’ftpserver.py’, {’modify’: ’20210515142003’, ’perm’: ’radfw’, ’size’: ’1661’, ’type’: ’file’})(’node.txt’, {’modify’: ’20210515141442’, ’perm’: ’radfw’, ’size’: ’12’, ’type’: ’file’})[root@localhost python]# ls # node.txt文件被下載到客戶端ftp.py ftpserver.py node.txt
到windows的test目錄下驗(yàn)證
ftpserver.py文件被上傳到服務(wù)端
以上就是python一秒搭建FTP服務(wù)器的詳細(xì)內(nèi)容,更多關(guān)于python FTP服務(wù)器的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)2. 使用Python和百度語(yǔ)音識(shí)別生成視頻字幕的實(shí)現(xiàn)3. python基于socket模擬實(shí)現(xiàn)ssh遠(yuǎn)程執(zhí)行命令4. Gitlab CI-CD自動(dòng)化部署SpringBoot項(xiàng)目的方法步驟5. Java封裝數(shù)組實(shí)現(xiàn)包含、搜索和刪除元素操作詳解6. ASP中解決“對(duì)象關(guān)閉時(shí),不允許操作?!钡脑幃悊?wèn)題……7. Django:使用filter的pk進(jìn)行多值查詢操作8. 淺談SpringMVC jsp前臺(tái)獲取參數(shù)的方式 EL表達(dá)式9. idea打開多個(gè)窗口的操作方法10. JAVA上加密算法的實(shí)現(xiàn)用例
