socket实现ftp文件的上传和下载

server端代码:

import socket
import json
import struct
import os
soc = socket.socket(socket.AF_INET, socket.SOCK_STREAM) soc.bind(('127.0.0.1', 8021)) soc.listen(5)
# 上传函数
def uploading_file():
while True:
try:
ftp_dir = r'F:\shpython11\pycharmwork\first_project\study_start\day32\ftp_dir'
if not os.path.isdir(ftp_dir): # 这个是作为我们上传了之后的文件放在这个位置,你改成自己本地的
os.mkdir(ftp_dir)
head_bytes_len = conn.recv(4) # 拿到struct后的头长度 head_len = struct.unpack('i', head_bytes_len)[0] # 取出真正的头长度 # 拿到真正的头部内容
head_bytes = conn.recv(head_len)
# 反序列化后取出头
head = json.loads(head_bytes) file_name = head['file_name']
file_path = os.path.join(ftp_dir,file_name)
data_len = head['data_len']
with open(file_path, 'wb') as fw:
while data_len > 1024:
fw.write(conn.recv(1024))
data_len -= 1024
else:
fw.write(conn.recv(data_len))
conn.send(f'上传文件 {file_name} 成功'.encode('utf8'))
except Exception:
break while True:
print('等待客户端连接。。。')
conn, addr = soc.accept()
print('客户端已连接:', addr)
choice = conn.recv(1).decode('utf8')
if choice == 'q':
break
if choice == '1':
print('客户端选择了ftp上传服务')
uploading_file()
elif choice == '2':
print('客户端选择了ftp下载服务')
while True:
try:
ftp_dir = r'F:\shpython11\pycharmwork\first_project\study_start\day32\ftp_dir'
if not os.path.isdir(ftp_dir): # 这个是作为我们上传了之后的文件放在这个位置,你改成自己本地的
os.mkdir(ftp_dir)
file_list = os.listdir(ftp_dir)
head = {'file_list': file_list}
head_bytes = json.dumps(head).encode('utf8')
head_bytes_len = struct.pack('i', len(head_bytes)) conn.send(head_bytes_len)
conn.send(head_bytes) client_head_bytes_len = conn.recv(4) client_head_len = struct.unpack('i', client_head_bytes_len)[0]
client_head_bytes = conn.recv(client_head_len)
client_head = json.loads(client_head_bytes)
choice = client_head['choice']
file_name = file_list[int(choice)] file_path = os.path.join(ftp_dir, file_name) with open(file_path, 'rb') as fr:
data = fr.read() server_head = {'data_len': len(data), 'file_name': file_name} # 自定义头
server_head_bytes = json.dumps(server_head).encode('utf8')
server_head_bytes_len = struct.pack('i', len(server_head_bytes)) conn.send(server_head_bytes_len)
conn.send(server_head_bytes)
conn.send(data)
conn.send(f'下载文件 {file_name} 成功'.encode('utf8')) except Exception:
break conn.close()
soc.clone()

client端代码:

import socket
import os
import struct
import json
client_soc = socket.socket() client_soc.connect(('127.0.0.1',8021)) # 获取文件夹下的文件
def get_file_list(file_path):
if os.path.exists(file_path):
if os.path.isfile(file_path):
return True,file_path
else:
file_list = os.listdir(file_path)
if file_list==[]:
return False,'当前文件夹为空,请重新选择'
else:
return True,file_list
else:
return False,'你输入的文件路径不对' # 上传函数
def uploading_file():
print('欢迎进入ftp文件上传系统')
while True:
dir_path = input('请输入文件所在的文件夹路径或文件路径(输入q退出):') if dir_path == 'q':
print('你选择了退出上传系统')
break
flag, dir_list = get_file_list(dir_path)
if flag:
if os.path.isfile(dir_path):
file_name = dir_path.split('\\')[-1]
file_path = dir_path
else:
for ind, file in enumerate(dir_list):
print(f'文件编号:{ind} 对应的文件名为:{file}')
choice = input('请输入文件编号进行上传:').strip()
choice = int(choice)
file_name = dir_list[choice]
file_path = os.path.join(dir_path, file_name) with open(file_path,'rb') as fr:
data = fr.read()
head = { 'data_len': len(data),'file_name':file_name} # 自定义头
head_bytes = json.dumps(head).encode('utf8')
head_bytes_len = struct.pack('i',len(head_bytes)) client_soc.send(head_bytes_len)
client_soc.send(head_bytes)
client_soc.send(data)
msg = client_soc.recv(1024)
print(msg.decode('utf8'))
else:
print('你输入的文件路径不存在') # 下载函数
def download():
print('欢迎来到ftp下载系统')
head_bytes_len = client_soc.recv(4)
head_len = struct.unpack('i', head_bytes_len)[0]
head_bytes = client_soc.recv(head_len)
head = json.loads(head_bytes)
file_list = head['file_list']
if file_list == []:
print('当前ftp中无文件可下载,等待上传中')
else:
print('当前ftp中有如下文件')
for ind,file in enumerate(file_list):
print(f'文件编号:{ind} 对应的文件名为:{file}')
choice = input('请选择要下载文件的编号:')
choice_head = {'choice':choice} # 自定义头 choice_head_bytes = json.dumps(choice_head).encode('utf8') choice_head_bytes_len = struct.pack('i', len(choice_head_bytes))
client_soc.send(choice_head_bytes_len)
client_soc.send(choice_head_bytes) # 接收用户传递过来的文件
client_head_bytes_len = client_soc.recv(4) # 拿到struct后的头长度 client_head_len = struct.unpack('i', client_head_bytes_len)[0] # 取出真正的头长度
# 拿到真正的头部内容
client_head_bytes = client_soc.recv(client_head_len)
# 反序列化后取出头
client_head = json.loads(client_head_bytes)
file_name = client_head['file_name']
data_len = client_head['data_len'] with open(file_name, 'wb') as fw:
while data_len > 1024:
fw.write(client_soc.recv(1024))
data_len -= 1024
else:
fw.write(client_soc.recv(data_len))
msg = client_soc.recv(1024)
print(msg.decode('utf8')) while True:
msg = '''
1.文件上传
2.文件下载
q.退出系统
'''
print(msg)
choice = input('请做出你的选择:').strip()
client_soc.send(choice.encode('utf8'))
if choice == 'q':
print('你选择了退出系统')
break
if choice == '1':
uploading_file() elif choice == '2':
download()

socket实现ftp上传下载的更多相关文章

  1. socket实现FTP上传下载功能

    '''服务器端''' 1 _author__ = "Dbass" import socketserver import json,os class MyTCPHandler(soc ...

  2. python之实现ftp上传下载代码(含错误处理)

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #python之实现ftp上传下载代码(含错误处理) #http://www.cnblogs.com/kait ...

  3. FTP上传下载文件(函数简易版)

    FTP上传下载文件(函数简易版) # 服务端 import socket import json import hashlib import struct import os user_dic = { ...

  4. JAVA 实现FTP上传下载(sun.net.ftp.FtpClient)

    package com.why.ftp; import java.io.DataInputStream; import java.io.File; import java.io.FileInputSt ...

  5. windows系统下ftp上传下载和一些常用命令

    先假设一个ftp地址 用户名 密码 FTP Server: home4u.at.china.com User: yepanghuang Password: abc123 打开windows的开始菜单, ...

  6. windows下ftp上传下载和一些常用命令

    先假设一个ftp地址 用户名 密码 FTP Server: home4u.at.china.com User: yepanghuang Password: abc123 打开windows的开始菜单, ...

  7. FTP上传下载工具(FlashFXP) v5.5.0 中文版

    软件名称: FTP上传下载工具(FlashFXP) 软件语言: 简体中文 授权方式: 免费试用 运行环境: Win 32位/64位 软件大小: 7.4MB 图片预览: 软件简介: FlashFXP 是 ...

  8. 高可用的Spring FTP上传下载工具类(已解决上传过程常见问题)

    前言 最近在项目中需要和ftp服务器进行交互,在网上找了一下关于ftp上传下载的工具类,大致有两种. 第一种是单例模式的类. 第二种是另外定义一个Service,直接通过Service来实现ftp的上 ...

  9. C# -- FTP上传下载

    C# -- FTP上传下载 1. C#实现FTP下载 private static void TestFtpDownloadFile(string strFtpPath, string strFile ...

随机推荐

  1. Python中xml和dict格式转换

    在做接口自动化的时候,请求数据之前都是JSON格式的,Python有自带的包来解决.最近在做APP的接口,遇到XML格式的请求数据,费了很大劲来解决,解决方式是:接口文档拿到的是XML,在线转化为js ...

  2. 说说 Python3 中的数字处理

    最近在处理订单相关的问题,踩了数字的一些坑,在此记录下. 其中有问题的代码涉及金额比较,便于描述,假设了下面一段代码 def is_paid(pay_price, paid_price): retur ...

  3. Go调用cpp类

    CGO是C语言和Go语言之间的桥梁,所以GO是没有办法直接使用CPP的类的. 我们可以通过增加一族C语言函数接口作为CPP类和CGO之前的桥梁的,这样 就可以实现C和Go之间的互联. my_buffe ...

  4. 利用python的requests和BeautifulSoup库爬取小说网站内容

    1. 什么是Requests? Requests是用Python语言编写的,基于urllib3来改写的,采用Apache2 Licensed 来源协议的HTTP库. 它比urllib更加方便,可以节约 ...

  5. ApplicationContext refresh 过程及一些重要的 processor 解析

    回顾 上文 其实我们已经实现了一个简单的 BeanFactory 它具的功能有 注册 Bean 到容器,通过限定名获取 Bean 可以拦截 Bean 初始化前后的处理 可以在 Bean 属性注入后和即 ...

  6. Pandas分类(category)数据处理

    分类(Category)数据:直白来说,就是取值为有限的,或者说是固定数量的可能值.例如:性别.血型 指定数据类型构建分类数据 dtype="category" 以血型为例,创建一 ...

  7. 使用Typescript重构axios(二十七)——添加请求状态码合法性校验

    0. 系列文章 1.使用Typescript重构axios(一)--写在最前面 2.使用Typescript重构axios(二)--项目起手,跑通流程 3.使用Typescript重构axios(三) ...

  8. access,trunk,hybrid端口分析

    1.access 接收:当数据没有tag时打上pvidtag进入,若有则看是否与pvid相等,相等则接收,不想等则丢弃. 转发:看tag是否等于pvid,若等则去tag发送,否则不处理. 2.trun ...

  9. PyCharm使用正则替换python中的静态资源

    python每次开发前台页面时,最无法避免的就是前台静态资源地址的替换了,手动替换成{% static 'web/.......' %}可想而知的痛苦,把正则替换的方式分享给朋友们,希望可以帮助到需要 ...

  10. java多线程与线程并发二:线程互斥

    本文章内容整理自:张孝祥_Java多线程与并发库高级应用视频教程 当两条线程访问同一个资源时,可能会出现安全隐患.以打印字符串为例,先看下面的代码: // public class Test2 { p ...