FTP上传下载文件(面向对象版)
# 服务端
import socketserver
import os
import json
import hashlib
import struct
class MySocketServer(socketserver.BaseRequestHandler):
users = []
@staticmethod
def get_dic(): # 获取密码库
user_dic = {}
file_name = 'register'
if file_name not in os.listdir(os.path.dirname(__file__)):
return user_dic
else:
with open(os.path.join(os.path.dirname(__file__), file_name), mode='r', encoding='utf-8') as f:
for line in f:
if line:
username, psw = line.strip().split('|')
user_dic[username] = psw
return user_dic
def logon(self): # 注册
user_dic = self.get_dic()
time = 3
while time > 0:
username, psw = self.request.recv(1024).decode('utf-8').split('|')
if 0 <= len(username) <= 20 and 6 <= len(psw) <= 20 and (username not in user_dic):
with open(os.path.join(os.path.dirname(__file__), 'register'), mode='a', encoding='utf-8') as f:
md5 = hashlib.md5()
md5.update(psw.encode('utf-8'))
f.write(f'{username}|{md5.hexdigest()}\n')
self.request.send('True'.encode())
MySocketServer.users.append(username)
self.user = username
return True
else:
time -= 1
self.request.send(str(time).encode('utf-8'))
return False
def login(self): # 登录
time = 3
user_dic = self.get_dic()
while time > 0:
username, psw = self.request.recv(1024).decode('utf-8').split('|')
md5 = hashlib.md5()
md5.update(psw.encode('utf-8'))
if user_dic.get(username) == md5.hexdigest() and username not in MySocketServer.users:
self.request.send('True'.encode())
MySocketServer.users.append(username)
self.user = username
return True
else:
time -= 1
self.request.send(str(time).encode('utf-8'))
return False
def up(self): # 上传
while 1:
len_head_dic = struct.unpack('i', self.request.recv(4))[0]
head_dic = json.loads(self.request.recv(len_head_dic).decode('utf-8'))
file_name = head_dic['file_name']
file_md5 = head_dic['file_md5']
file_size = head_dic['file_size']
if self.user not in os.listdir(os.path.join(os.path.dirname(__file__), '用户文件')):
os.makedirs(f'用户文件/{self.user}')
file_path = os.path.join(os.path.dirname(__file__), f'用户文件/{self.user}', file_name)
with open(file_path, mode='wb') as f:
md5 = hashlib.md5()
len_data = 0
while len_data < file_size:
data = self.request.recv(1024)
len_data += len(data)
md5.update(data)
f.write(data)
data_md5 = md5.hexdigest()
if data_md5 == file_md5:
self.request.send('True'.encode('utf-8'))
return True
else:
self.request.send('False'.encode('utf-8'))
def down(self): # 下载
file_path = os.path.join(os.path.dirname(__file__), '用户文件')
file_user = os.listdir(file_path)
if self.user not in file_user or not os.listdir(os.path.join(file_path, f'{self.user}')):
self.request.send('False'.encode('utf-8'))
else:
file_lst = os.listdir(os.path.join(file_path, f'{self.user}'))
file_show = ''
for n, file in enumerate(file_lst, 1):
file_show += f'序号:{n}\t文件名:{file}\n'
to_client = f'可下载文件:\n{file_show}'.encode('utf-8')
self.request.send(to_client)
while 1:
from_client = self.request.recv(1024).decode('utf-8')
try:
with open(os.path.join(file_path, f'{self.user}', file_lst[int(from_client) - 1]), mode='rb') as f:
file_size = 0
md5 = hashlib.md5()
while 1:
data = f.read(1024)
if data:
md5.update(data)
file_size += len(data)
else:
break
file_md5 = md5.hexdigest()
self.request.send('True'.encode('utf-8'))
except Exception:
self.request.send('False.'.encode('utf-8'))
continue
else:
head_dic = {
'file_md5': file_md5,
'file_name': file_lst[int(from_client) - 1],
'file_size': file_size
}
head_dic_json_bytes = json.dumps(head_dic).encode('utf-8')
len_head_dic_bytes = struct.pack('i', len(head_dic_json_bytes))
self.request.send(len_head_dic_bytes)
self.request.send(head_dic_json_bytes)
with open(os.path.join(file_path, f'{self.user}', file_lst[int(from_client) - 1]), mode='rb') as f:
while 1:
data = f.read(1024)
if data:
self.request.send(data)
else:
return True
def handle(self):
while 1:
try:
from_client = self.request.recv(1024).decode('utf-8')
func = getattr(self, from_client)
ret = func()
if ret == False:
break
except Exception:
MySocketServer.users.remove(self.user)
break
server = socketserver.ThreadingTCPServer(('192.168.13.19', 2020), MySocketServer)
server.serve_forever() # 对象执行serve_forever方法,开启服务端
# 客户端
import socket
import os
import json
import hashlib
import struct
import sys
import time
def progress(percent, width=50): # 打印进度条
if percent >= 1:
percent = 1
show_str = ('%%-%ds' % width) % (int(width*percent)*'|')
print('\r%s %d%%' %(show_str, int(100*percent)), end='')
class MyClient:
login_logon = {'1': 'login',
'2': 'logon'}
func_dic = {
'1': 'up',
'2': 'down',
'3': 'exit'
}
def __init__(self, name, ip, port):
self.name = name
self.socket = socket.socket()
self.socket.connect((ip, port))
def logon(self): # 注册
print('-----欢迎访问注册页面-----')
while 1:
username = input('请输入用户名:').strip()
psw = input('请输入密码:').strip()
self.socket.send(f'{username}|{psw}'.encode('utf-8'))
from_server = self.socket.recv(1024).decode('utf-8')
if from_server == 'True':
print('恭喜你,注册成功~~~~~~~~')
return True
elif from_server == '0':
print('啊哈,注册失败了,正在退出....')
return False
else:
print(f'再来一次吧,还有{from_server}次机会~~~~')
def login(self): # 登录
print('-----欢迎访问登录页面-----')
while 1:
username = input('请输入用户名:').strip()
psw = input('请输入密码:').strip()
self.socket.send(f'{username}|{psw}'.encode('utf-8'))
from_server = self.socket.recv(1024).decode('utf-8')
if from_server == 'True':
print('恭喜你,登录成功~~~~~~~~')
return True
elif from_server == '0':
print('啊哈,登录失败了,正在退出....')
return False
else:
print(f'再来一次吧,还有{from_server}次机会~~~~')
def up(self): # 上传
print('-----欢迎访问上传页面-----')
while 1:
file_path = input('请输入上传的文件路径:').strip()
try:
with open(file_path, mode='rb') as f:
file_size = 0
md5 = hashlib.md5()
while 1:
data = f.read(1024)
if data:
md5.update(data)
file_size += len(data)
else:
break
file_md5 = md5.hexdigest()
except Exception:
print('路径错误,请重新输入.')
continue
else:
head_dic = {
'file_md5': file_md5,
'file_name': os.path.basename(file_path),
'file_size': file_size
}
head_dic_json_bytes = json.dumps(head_dic).encode('utf-8')
len_head_dic_bytes = struct.pack('i', len(head_dic_json_bytes))
self.socket.send(len_head_dic_bytes)
self.socket.send(head_dic_json_bytes)
with open(file_path, mode='rb') as f:
data_size = 0
while 1:
data = f.read(1024)
if data:
self.socket.send(data)
data_size += len(data)
percent = data_size / file_size
progress(percent, width=70)
else:
break
from_server = self.socket.recv(1024).decode('utf-8')
if from_server == 'True':
print('恭喜你,上传成功.')
return True
else:
print('啊哈,上传失败.')
def down(self): # 下载
print('-----欢迎访问下载页面-----')
from_server = self.socket.recv(1024).decode('utf-8')
if from_server == 'False':
print('你的云盘为空,请先上传文件~~~~~~')
else:
print(from_server)
while 1:
choice = input('请输入选择的序号:').strip().encode('utf-8')
self.socket.send(choice)
return_from_server = self.socket.recv(1024).decode('utf-8')
if return_from_server == 'True':
len_head_dic = struct.unpack('i', self.socket.recv(4))[0]
head_dic = json.loads(self.socket.recv(len_head_dic).decode('utf-8'))
file_name = head_dic['file_name']
file_md5 = head_dic['file_md5']
file_size = head_dic['file_size']
file_path = os.path.join(os.path.dirname(__file__), '下载', file_name)
with open(file_path, mode='wb') as f:
md5 = hashlib.md5()
len_data = 0
while len_data < file_size:
data = self.socket.recv(1024)
len_data += len(data)
md5.update(data)
f.write(data)
percent = len_data / file_size
progress(percent, width=70)
percent = len_data / file_size
progress(percent, width=70)
data_md5 = md5.hexdigest()
if data_md5 == file_md5:
print('下载成功.')
return True
else:
print('下载失败.')
else:
print('输入错误,请重新输入.')
def exit(self): # 退出
print('正在退出~~~~~~')
exit()
def run(self):
print('-----[1]登录[2]注册-----')
while 1:
choice = input('请输入选项:').strip()
if choice in self.login_logon:
self.socket.send(self.login_logon[choice].encode('utf-8'))
func = getattr(self, self.login_logon[choice])
ret = func()
if ret:
while 1:
print('-----[1]上传[2]下载[3]退出-----')
choice_func = input('请输入选项:').strip()
if choice in self.func_dic:
self.socket.send(self.func_dic[choice_func].encode('utf-8'))
method = getattr(self, self.func_dic[choice_func])
method()
else:
print('输入错误,请重新输入.')
else:
break
else:
print('输入错误,请重新输入.')
client = MyClient('客户端', '192.168.13.19', 2020)
client.run()
FTP上传下载文件(面向对象版)的更多相关文章
- FTP上传下载文件(函数简易版)
FTP上传下载文件(函数简易版) # 服务端 import socket import json import hashlib import struct import os user_dic = { ...
- java客户端调用ftp上传下载文件
1:java客户端上传,下载文件. package com.li.utils; import java.io.File; import java.io.FileInputStream; import ...
- shell ftp上传下载文件
1. ftp自动登录批量下载文件. #####从ftp服务器上的/home/data 到 本地/home/databackup#### #!/bin/bash ftp -n<<! open ...
- shell脚本实现ftp上传下载文件
前段时间工作中需要将经过我司平台某些信息核验数据提取后上传到客户的FTP服务器上,以便于他们进行相关的信息比对核验.由于包含这些信息的主机只有4台,采取的策略是将生成的4个文件汇集到一个主机上,然后在 ...
- python实现支持目录FTP上传下载文件的方法
#!/usr/bin/env python # -*- coding: utf-8 -*- import ftplib import os import sys class FTPSync(objec ...
- 如何通过SecureCRT FTP上传下载文件
通过SecureCRT FTP方式从一台机器下载文件到另一台机器上: [root@TEST144239 ~]# ftp 10.30.1.25 Connected to 10.30.1.25 (10. ...
- ftp上传下载文件
客户端client: import os import json import socket import struct sk = socket.socket() sk.connect(('127.0 ...
- shell通过ftp实现上传/下载文件
直接代码,shell文件名为testFtptool.sh: #!/bin/bash ########################################################## ...
- JAVA 实现FTP上传下载(sun.net.ftp.FtpClient)
package com.why.ftp; import java.io.DataInputStream; import java.io.File; import java.io.FileInputSt ...
随机推荐
- 【学习总结】gcc和gdb
目录 <> vim.gcc.gdb: gcc: gcc和g++是c/c++的linux系统集成的编译器,源文件的后缀应为 .C/.cpp/.c++/.cc等 编译器可以将C.C++等语言源 ...
- ERROR in Template execution failed: ReferenceError: htmlwebpackPlugin is not defined
ejs文件配置如下: <!DOCTYPE html> <html lang="zh-CN"> <head> <title>webpa ...
- day03 for循环、字符串方法、类型转换
01 上周内容回顾 while 条件: 循环体 例: while True: print(111) print(222) print(333) 结束循环的两种方式: 1,改变条件. 2,break. ...
- html5中play 方法和pause方法在video的应用
play();播放 pause();暂停 代码实例: <!DOCTYPE html> <html lang="en"> <head> <m ...
- RabbitMQ:伪延时队列
目录 一.什么是延时队列 二.RabbitMQ实现 三. 延时队列的问题 四.解决RabbitMQ的伪延时方案 ps:伪延时队列先卖个关子,我们先了解下延时队列. 一.什么是延时队列 所谓延时队列是指 ...
- 基因id
每个物种都有一个对应的Taxonomy ID: 9606 :人类 10090 :小鼠
- fat文件系统
在主引导区后面就是FAT表.从上面可以得知一个FAT表是229个扇区.它里边的内容很简单,里边的内容就是指出下一个簇在哪里.你的盘有多少个簇,那么它的FAT表就要有多少个项来描述它们.因为FAT16是 ...
- 英语单词contributors
contributors 来源——github网站 翻译 n. 贡献者:参与者:编著者(contributor的复数形式) TOEFL | GMAT 词根:cont ...
- SSM项目用ajax来显示数据
<script type="text/javascript"> //1:页面加载完成后,直接去发送ajax请求,要到分页的数据 $(function(){ $.ajax ...
- express中 使用session与cookie
1.express如何使用session与cookie : https://www.jianshu.com/p/1839e482274e 或 https://www.cnblogs.com/chy ...