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

Python實現(xiàn)的FTP通信客戶端與服務器端功能示例

 更新時間:2018年03月28日 11:40:43   作者:chengqiuming  
這篇文章主要介紹了Python實現(xiàn)的FTP通信客戶端與服務器端功能,涉及Python基于socket的端口監(jiān)聽、文件傳輸?shù)认嚓P操作技巧,需要的朋友可以參考下

本文實例講述了Python實現(xiàn)的FTP通信客戶端與服務器端功能。分享給大家供大家參考,具體如下:

一 代碼

1、服務端代碼

import socket
import threading
import os
import struct
#用戶賬號、密碼、主目錄
#也可以把這些信息存放到數(shù)據庫中
users = {'zhangsan':{'pwd':'zhangsan1234', 'home':r'c:\python 3.5'},
     'lisi':{'pwd':'lisi567', 'home':'c:\\'}}
def server(conn,addr, home):
  print('新客戶端:'+str(addr))
  #進入當前用戶主目錄
  os.chdir(home)
  while True:
    data = conn.recv(100).decode().lower()
    #顯示客戶端輸入的每一條命令
    print(data)
    #客戶端退出
    if data in ('quit', 'q'):
      break
    #查看當前文件夾的文件列表
    elif data in ('list', 'ls', 'dir'):
      files = str(os.listdir(os.getcwd()))
      files = files.encode()
      conn.send(struct.pack('I', len(files)))
      conn.send(files)
    #切換至上一級目錄
    elif ''.join(data.split()) == 'cd..':
      cwd = os.getcwd()
      newCwd = cwd[:cwd.rindex('\\')]
      #考慮根目錄的情況
      if newCwd[-1] == ':':
        newCwd += '\\'
      #限定用戶主目錄
      if newCwd.lower().startswith(home):
        os.chdir(newCwd)
        conn.send(b'ok')
      else:
        conn.send(b'error')
    #查看當前目錄
    elif data in ('cwd', 'cd'):
      conn.send(str(os.getcwd()).encode())
    elif data.startswith('cd '):
      #指定最大分隔次數(shù),考慮目標文件夾帶有空格的情況
      #只允許使用相對路徑進行跳轉
      data = data.split(maxsplit=1)
      if len(data) == 2 and os.path.isdir(data[1]) \
        and data[1]!=os.path.abspath(data[1]):
        os.chdir(data[1])
        conn.send(b'ok')
      else:
        conn.send(b'error')
    #下載文件
    elif data.startswith('get '):
      data = data.split(maxsplit=1)
      #檢查文件是否存在
      if len(data) == 2 and os.path.isfile(data[1]):
        conn.send(b'ok')
        fp = open(data[1], 'rb')
        while True:
          content = fp.read(4096)
          #發(fā)送文件結束
          if not content:
            conn.send(b'overxxxx')
            break
          #發(fā)送文件內容
          conn.send(content)
          if conn.recv(10) == b'ok':
            continue
        fp.close()
      else:
        conn.send(b'no')
    #無效命令
    else:
      pass
  conn.close()
  print(str(addr)+'關閉連接')
#創(chuàng)建Socket,監(jiān)聽本地端口,等待客戶端連接
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.bind(('', 10600))
sock.listen(5)
while True:
  conn, addr = sock.accept()
  #驗證客戶端輸入的用戶名和密碼是否正確
  userId, userPwd = conn.recv(1024).decode().split(',')
  if userId in users and users[userId]['pwd'] == userPwd:
    conn.send(b'ok')
    #為每個客戶端連接創(chuàng)建并啟動一個線程,參數(shù)為連接、客戶端地址、客戶主目錄
    home = users[userId]['home']
    t = threading.Thread(target=server, args=(conn,addr,home))
    t.daemon = True
    t.start()
  else:
    conn.send(b'error')

2、客戶端代碼

import socket
import sys
import re
import struct
import getpass
def main(serverIP):
  sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  sock.connect((serverIP, 10600))
  userId = input('請輸入用戶名:')
  #使用getpass模塊的getpass()方法獲取密碼,不回顯
  userPwd = getpass.getpass('請輸入密碼:')
  message = userId+','+userPwd
  sock.send(message.encode())
  login = sock.recv(100)
  #驗證是否登錄成功
  if login == b'error':
    print('用戶名或密碼錯誤')
    return
  #整數(shù)編碼大小
  intSize = struct.calcsize('I')
  while True:
    #接收客戶端命令,其中##>是提示符
    command = input('##> ').lower().strip()
    #沒有輸入任何有效字符,提前進入下一次循環(huán),等待用戶繼續(xù)輸入
    if not command:
      continue
    #向服務端發(fā)送命令
    command = ' '.join(command.split())
    sock.send(command.encode())
    #退出
    if command in ('quit', 'q'):
      break
    #查看文件列表
    elif command in ('list', 'ls', 'dir'):
      loc_size = struct.unpack('I', sock.recv(intSize))[0]
      files = eval(sock.recv(loc_size).decode())
      for item in files:
        print(item)
    #切換至上一級目錄
    elif ''.join(command.split()) == 'cd..':
      print(sock.recv(100).decode())
    #查看當前工作目錄
    elif command in ('cwd', 'cd'):
      print(sock.recv(1024).decode())
    #切換至子文件夾
    elif command.startswith('cd '):
      print(sock.recv(100).decode())
    #從服務器下載文件
    elif command.startswith('get '):
      isFileExist = sock.recv(20)
      #文件不存在
      if isFileExist != b'ok':
        print('error')
      #文件存在,開始下載
      else:
        print('downloading.', end='')
        fp = open(command.split()[1], 'wb')
        while True:
          print('.', end='')
          data = sock.recv(4096)
          if data == b'overxxxx':
            break
          fp.write(data)
          sock.send(b'ok')
        fp.close()
        print('ok')
    #無效命令
    else:
      print('無效命令')
  sock.close()
if __name__ == '__main__':
  if len(sys.argv) != 2:
    print('Usage:{0} serverIPAddress'.format(sys.argv[0]))
    exit()
  serverIP = sys.argv[1]
  if re.match(r'^\d{1,3}.\d{1,3}.\d{1,3}.\d{1,3}$', serverIP):
    main(serverIP)
  else:
    print('服務器地址不合法')
    exit()

二 運行結果

客戶端運行結果

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python Socket編程技巧總結》、《Python URL操作技巧總結》、《Python數(shù)據結構與算法教程》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經典教程

希望本文所述對大家Python程序設計有所幫助。

相關文章

  • 十行代碼使用Python寫一個USB病毒

    十行代碼使用Python寫一個USB病毒

    本文給大家分享一個基于十行代碼使用Python寫一個USB病毒,很簡單,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • Python計算質數(shù)的方法總結

    Python計算質數(shù)的方法總結

    質數(shù)(Prime?Number)是指大于1且只能被1和自身整除的正整數(shù),計算質數(shù)是數(shù)論中的一個經典問題,本文將介紹python中多種計算質數(shù)的方法,希望對大家有所幫助
    2023-11-11
  • python 實現(xiàn)在txt指定行追加文本的方法

    python 實現(xiàn)在txt指定行追加文本的方法

    下面小編就為大家分享一篇python 實現(xiàn)在txt指定行追加文本的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • Python3和pyqt5實現(xiàn)控件數(shù)據動態(tài)顯示方式

    Python3和pyqt5實現(xiàn)控件數(shù)據動態(tài)顯示方式

    今天小編就為大家分享一篇Python3和pyqt5實現(xiàn)控件數(shù)據動態(tài)顯示方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • python中JSON數(shù)據格式的詳細使用教程

    python中JSON數(shù)據格式的詳細使用教程

    這篇文章主要給大家介紹了關于python中JSON數(shù)據格式的詳細使用,JSON是一種用于存儲和交換數(shù)據的語法,JSON是文本,使用JavaScript對象表示法編寫,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • python實現(xiàn)批量命名照片

    python實現(xiàn)批量命名照片

    這篇文章主要為大家詳細介紹了python實現(xiàn)批量命名照片,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • Python利用3D引擎制作一個3D迷宮游戲

    Python利用3D引擎制作一個3D迷宮游戲

    Python有一個不錯的3D引擎——Ursina。本文就來利用Ursina這一引擎制作一個簡單的3D迷宮游戲,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-01-01
  • Python開發(fā)游戲自動化后臺腳本的實現(xiàn)

    Python開發(fā)游戲自動化后臺腳本的實現(xiàn)

    本文主要介紹了Python開發(fā)游戲自動化后臺腳本的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • python自帶tkinter庫實現(xiàn)棋盤覆蓋圖形界面

    python自帶tkinter庫實現(xiàn)棋盤覆蓋圖形界面

    這篇文章主要為大家詳細介紹了python自帶tkinter庫實現(xiàn)棋盤覆蓋圖形界面,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • python利用標準庫如何獲取本地IP示例詳解

    python利用標準庫如何獲取本地IP示例詳解

    這篇文章主要給大家介紹了關于python利用標準庫如何獲取本地IP的相關資料,文中先對python的標準庫進行了簡單的介紹,而后給大家詳細介紹了關于python用標準庫獲取本地IP的實現(xiàn)方法,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。
    2017-11-11

最新評論