欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)FTP服務(wù)器服務(wù)的方法

 更新時間:2017年04月11日 15:04:41   作者:黃小墨  
本篇文章主要介紹了python實現(xiàn)FTP服務(wù)器的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

FTP服務(wù)的主動模式和被動模式

在開始之前,先聊一下FTP的主動模式和被動模式,兩者的區(qū)別 , 用兩張圖來表示可能會更加清晰一些:

主動模式:

主動模式工作過程:

1. 客戶端以隨機非特權(quán)端口N,就是大于1024的端口,對server端21端口發(fā)起連接

2. 客戶端開始監(jiān)聽 N+1端口;

3. 服務(wù)端會主動以20端口連接到客戶端的N+1端口。

主動模式的優(yōu)點:

服務(wù)端配置簡單,利于服務(wù)器安全管理,服務(wù)器只需要開放21端口

主動模式的缺點:

如果客戶端開啟了防火墻,或客戶端處于內(nèi)網(wǎng)(NAT網(wǎng)關(guān)之后), 那么服務(wù)器對客戶端端口發(fā)起的連接可能會失敗

被動模式:

被動模式工作過程:

1. 客戶端以隨機非特權(quán)端口連接服務(wù)端的21端口

2. 服務(wù)端開啟一個非特權(quán)端口為被動端口,并返回給客戶端

3. 客戶端以非特權(quán)端口+1的端口主動連接服務(wù)端的被動端口

被動模式缺點:

服務(wù)器配置管理稍顯復(fù)雜,不利于安全,服務(wù)器需要開放隨機高位端口以便客戶端可以連接,因此大多數(shù)FTP服務(wù)軟件都可以手動配置被動端口的范圍

被動模式的優(yōu)點:對客戶端網(wǎng)絡(luò)環(huán)境沒有要求

了解了FTP之后,開始使用python來實現(xiàn)FTP服務(wù)

準備工作

本次使用python版本:python 3.4.3

安裝模塊 pyftpdlib

pip3 install pyftpdlib

創(chuàng)建代碼文件 FtpServer.py

代碼

實現(xiàn)簡單的本地驗證

from pyftpdlib.authorizers import DummyAuthorizer
from pyftpdlib.handlers import FTPHandler
from pyftpdlib.servers import FTPServer

#實例化虛擬用戶,這是FTP驗證首要條件
authorizer = DummyAuthorizer()

#添加用戶權(quán)限和路徑,括號內(nèi)的參數(shù)是(用戶名, 密碼, 用戶目錄, 權(quán)限)
authorizer.add_user('user', '12345', '/home/', perm='elradfmw')

#添加匿名用戶 只需要路徑
authorizer.add_anonymous('/home/huangxm')

#初始化ftp句柄
handler = FTPHandler
handler.authorizer = authorizer

#監(jiān)聽ip 和 端口,因為linux里非root用戶無法使用21端口,所以我使用了2121端口
server = FTPServer(('192.168.0.108', 2121), handler)

#開始服務(wù)
server.serve_forever()

開啟服務(wù)

$python FtpServer.py

測試一下:

輸入個錯誤密碼試試:

驗證不通過,無法登錄 。

但這似乎是主動模式的FTP ,如何實現(xiàn)被動模式呢?

通過以下代碼添加被動端口:

handler.passive_ports = range(2000,2333)

完整代碼:

from pyftpdlib.authorizers import DummyAuthorizer
from pyftpdlib.handlers import FTPHandler
from pyftpdlib.servers import FTPServer

#實例化虛擬用戶,這是FTP驗證首要條件
authorizer = DummyAuthorizer()

#添加用戶權(quán)限和路徑,括號內(nèi)的參數(shù)是(用戶名, 密碼, 用戶目錄, 權(quán)限)
authorizer.add_user('user', '12345', '/home/', perm='elradfmw')

#添加匿名用戶 只需要路徑
authorizer.add_anonymous('/home/huangxm')

#初始化ftp句柄
handler = FTPHandler
handler.authorizer = authorizer

#添加被動端口范圍
handler.passive_ports = range(2000, 2333)

#監(jiān)聽ip 和 端口
server = FTPServer(('192.168.0.108', 2121), handler)

#開始服務(wù)
server.serve_forever()

開啟服務(wù),可以看到被動端口的信息:

$ python FtpServer.py 
[I 2017-01-11 15:18:37] >>> starting FTP server on 192.168.0.108:2121, pid=46296 <<<
[I 2017-01-11 15:18:37] concurrency model: async
[I 2017-01-11 15:18:37] masquerade (NAT) address: None
[I 2017-01-11 15:18:37] passive ports: 2000->2332

FTP用戶管理:

通過上面的實踐,F(xiàn)TP服務(wù)器已經(jīng)可以正常工作了,但是如果需要很多個FTP用戶呢,怎么辦呢? 每個用戶都寫一遍嗎?

其實我們可以定義一個用戶文件user.py

#用戶名   密碼    權(quán)限     目錄
# root   12345   elradfmwM  /home
huangxm   12345   elradfmwM  /home

然后遍歷該文件,將不以#開頭的行加入到user_list列表中

完整代碼:

from pyftpdlib.authorizers import DummyAuthorizer
from pyftpdlib.handlers import FTPHandler
from pyftpdlib.servers import FTPServer


def get_user(userfile):
  #定義一個用戶列表
  user_list = []
  with open(userfile) as f:
    for line in f:
      print(len(line.split()))
      if not line.startswith('#') and line:
        if len(line.split()) == 4: 
          user_list.append(line.split())
        else:
          print("user.conf配置錯誤")
  return user_list

#實例化虛擬用戶,這是FTP驗證首要條件
authorizer = DummyAuthorizer()

#添加用戶權(quán)限和路徑,括號內(nèi)的參數(shù)是(用戶名, 密碼, 用戶目錄, 權(quán)限)
#authorizer.add_user('user', '12345', '/home/', perm='elradfmw')
user_list = get_user('/home/huangxm/test_py/FtpServer/user.conf')
for user in user_list:
  name, passwd, permit, homedir = user
  try:
    authorizer.add_user(name, passwd, homedir, perm=permit)
  except Exception as e:
    print(e)

#添加匿名用戶 只需要路徑
authorizer.add_anonymous('/home/huangxm')

#初始化ftp句柄
handler = FTPHandler
handler.authorizer = authorizer

#添加被動端口范圍
handler.passive_ports = range(2000, 2333)

#監(jiān)聽ip 和 端口
server = FTPServer(('192.168.0.108', 2121), handler)

#開始服務(wù)
server.serve_forever()

到這里,F(xiàn)TP 服務(wù)已經(jīng)完成了。

規(guī)范一下代碼

首先創(chuàng)建conf目錄,存放settings.py和user.py

目錄結(jié)構(gòu)(cache里面的不用管):

setting.py

ip = '0.0.0.0'

port = '2121'

#上傳速度 300kb/s
max_upload = 300 * 1024

#下載速度 300kb/s
max_download = 300 * 1024

#最大連接數(shù)
max_cons = 150

#最多IP數(shù)
max_per_ip = 10

#被動端口范圍,注意被動端口數(shù)量要比最大IP數(shù)多,否則可能出現(xiàn)無法連接的情況
passive_ports = (2000, 2200)

#是否開啟匿名訪問 on|off
enable_anonymous = 'off'
#匿名用戶目錄
anonymous_path = '/home/huangxm'

#是否開啟日志 on|off
enable_logging = 'off'
#日志文件
loging_name = 'pyftp.log'

#歡迎信息
welcome_msg = 'Welcome to my ftp'

user.py

#用戶名   密碼    權(quán)限     目錄
#root   12345   elradfmwM  /home/
huangxm   12345   elradfmwM  /home/
test    12345   elradfmwM  /home/huangxm

FtpServer.py

from pyftpdlib.authorizers import DummyAuthorizer
from pyftpdlib.handlers import FTPHandler, ThrottledDTPHandler
from pyftpdlib.servers import FTPServer
from conf import settings
import logging


def get_user(userfile):
  #定義一個用戶列表
  user_list = []
  with open(userfile) as f:
    for line in f:
      if not line.startswith('#') and line:
        if len(line.split()) == 4: 
          user_list.append(line.split())
        else:
          print("user.conf配置錯誤")
  return user_list

def ftp_server():
  #實例化虛擬用戶,這是FTP驗證首要條件
  authorizer = DummyAuthorizer()
  
  #添加用戶權(quán)限和路徑,括號內(nèi)的參數(shù)是(用戶名, 密碼, 用戶目錄, 權(quán)限)
  #authorizer.add_user('user', '12345', '/home/', perm='elradfmw')
  user_list = get_user('conf/user.py')
  for user in user_list:
    name, passwd, permit, homedir = user
    try:
      authorizer.add_user(name, passwd, homedir, perm=permit)
    except Exception as e:
      print(e)

  #添加匿名用戶 只需要路徑
  if settings.enable_anonymous == 'on':
    authorizer.add_anonymous(settings.anonymous_path)
  
  #下載上傳速度設(shè)置
  dtp_handler = ThrottledDTPHandler
  dtp_handler.read_limit = settings.max_download
  dtp_handler.write_limit = settings.max_upload

  #初始化ftp句柄
  handler = FTPHandler
  handler.authorizer = authorizer

  #日志記錄
  if settings.enable_logging == 'on':
    logging.basicConfig(filename=settings.loging_name, level=logging.INFO)

  #歡迎信息
  handler.banner = settings.welcome_msg
  

  #添加被動端口范圍
  handler.passive_ports = range(settings.passive_ports[0], settings.passive_ports[1])

  #監(jiān)聽ip 和 端口
  server = FTPServer((settings.ip, settings.port), handler)
  
  #最大連接數(shù)
  server.max_cons = settings.max_cons
  server.max_cons_per_ip = settings.max_per_ip
  
  #開始服務(wù)
  print('開始服務(wù)')
  server.serve_forever()

if __name__ == "__main__":
  ftp_server()

最后,說一下權(quán)限問題

讀權(quán)限 :

e 改變文件目錄
l 列出文件
r 從服務(wù)器接收文件

寫權(quán)限 :

a 文件上傳
d 刪除文件
f 文件重命名
m 創(chuàng)建文件
w 寫權(quán)限
M 文件傳輸模式(通過FTP設(shè)置文件權(quán)限 )

M 示例:

到服務(wù)器上查看一下權(quán)限:

可以看到權(quán)限已經(jīng)被修改了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python實現(xiàn)動態(tài)繪圖的示例詳解

    Python實現(xiàn)動態(tài)繪圖的示例詳解

    matplotlib中的animation提供了動態(tài)繪圖功能,這篇文章主要為大家詳細介紹了Python如何利用matplotlib實現(xiàn)動態(tài)繪圖,感興趣的可以了解一下
    2023-05-05
  • python數(shù)據(jù)處理實戰(zhàn)(必看篇)

    python數(shù)據(jù)處理實戰(zhàn)(必看篇)

    下面小編就為大家?guī)硪黄猵ython數(shù)據(jù)處理實戰(zhàn)(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • numpy的Fancy Indexing和array比較詳解

    numpy的Fancy Indexing和array比較詳解

    這篇文章主要介紹了numpy的Fancy Indexing和array比較詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Python 實現(xiàn)網(wǎng)頁自動截圖的示例講解

    Python 實現(xiàn)網(wǎng)頁自動截圖的示例講解

    今天小編就為大家分享一篇Python 實現(xiàn)網(wǎng)頁自動截圖的示例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 利用tkinter改變下拉列表(Combobox)的選項值

    利用tkinter改變下拉列表(Combobox)的選項值

    這篇文章主要介紹了利用tkinter改變下拉列表(Combobox)的選項值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • python腳本框架webpy入門安裝及應(yīng)用創(chuàng)建

    python腳本框架webpy入門安裝及應(yīng)用創(chuàng)建

    這篇文章主要為大家介紹了python腳本框架web.py的入門安裝及應(yīng)用創(chuàng)建過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-11-11
  • Sublime Text v4.0(4143)安裝方法

    Sublime Text v4.0(4143)安裝方法

    這篇文章主要介紹了Sublime Text v4.0(4143)安裝破解方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • Python實現(xiàn)PPT/PPTX批量轉(zhuǎn)換成PDF

    Python實現(xiàn)PPT/PPTX批量轉(zhuǎn)換成PDF

    這篇文章主要為大家詳細介紹了如何使用Python將PowerPoint演示文稿(PPT、PPTX等)轉(zhuǎn)換為PDF文件,使演示內(nèi)容能夠在更多的設(shè)備上展示,感興趣的小伙伴可以了解下
    2024-01-01
  • python 編程之twisted詳解及簡單實例

    python 編程之twisted詳解及簡單實例

    這篇文章主要介紹了python 編程之twisted詳解及簡單實例的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • 對Django中static(靜態(tài))文件詳解以及{% static %}標簽的使用方法

    對Django中static(靜態(tài))文件詳解以及{% static %}標簽的使用方法

    今天小編就為大家分享一篇對Django中static(靜態(tài))文件詳解以及{% static %}標簽的使用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07

最新評論