FTP上传下载文件(函数简易版)
FTP上传下载文件(函数简易版)
# 服务端
import socket
import json
import hashlib
import struct
import os
user_dic = {
'太上老君': '123456',
'元始天尊': '123456',
'通天教主': '123456'
}
server = socket.socket()
server.bind(('192.168.13.19', 2021))
server.listen(5)
conn, addr = server.accept()
def login(): # 登录
time = 3
while time > 0:
username, psw = conn.recv(1024).decode('utf-8').split('|')
if user_dic.get(username) == psw:
conn.send('True'.encode('utf-8'))
return True
else:
time -= 1
conn.send(str(time).encode('utf-8'))
return False
def up(): # 上传
while 1:
len_head_dic = struct.unpack('i', conn.recv(4))[0]
head_dic = json.loads(conn.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 = conn.recv(1024)
len_data += len(data)
md5.update(data)
f.write(data)
data_md5 = md5.hexdigest()
if data_md5 == file_md5:
conn.send('True'.encode('utf-8'))
return True
else:
conn.send('False'.encode('utf-8'))
def down(): # 下载
file_path = os.path.join(os.path.dirname(__file__), '上传/')
file_lst = os.listdir(file_path)
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')
conn.send(to_client)
while 1:
from_client = conn.recv(1024).decode('utf-8')
try:
with open(os.path.join(file_path, 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()
conn.send('True'.encode('utf-8'))
except Exception:
conn.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))
conn.send(len_head_dic_bytes)
conn.send(head_dic_json_bytes)
with open(os.path.join(file_path, file_lst[int(from_client) - 1]), mode='rb') as f:
while 1:
data = f.read(1024)
if data:
conn.send(data)
else:
return True
def run(): # 主循环
if login():
while 1:
from_client = conn.recv(1024).decode('utf-8')
if from_client == '1':
up()
elif from_client == '2':
down()
elif from_client == '3':
break
if __name__ == '__main__':
run()
# 客户端
import socket
import hashlib
import json
import struct
import os
client = socket.socket()
client.connect(('192.168.13.19', 2021))
def login(): # 登录
while 1:
username = input('请输入账号:').strip()
psw = input('请输入密码:').strip()
to_server = f'{username}|{psw}'.encode('utf-8')
client.send(to_server)
from_server = client.recv(1024).decode('utf-8')
if from_server == 'True':
return True
elif from_server == '0':
return False
else:
print(f'账号或密码错误,还有{from_server}次机会')
def up(): # 上传
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))
client.send(len_head_dic_bytes)
client.send(head_dic_json_bytes)
with open(file_path, mode='rb') as f:
while 1:
data = f.read(1024)
if data:
client.send(data)
else:
break
from_server = client.recv(1024).decode('utf-8')
if from_server == 'True':
print('上传成功.')
return True
else:
print('上传失败.')
def down(): # 下载
print('欢迎进入下载页面~~~~~~~~~~~~~~~~~~')
from_server = client.recv(1024).decode('utf-8')
print(from_server)
while 1:
choice = input('请输入选择的序号:').strip().encode('utf-8')
client.send(choice)
return_from_server = client.recv(1024).decode('utf-8')
if return_from_server == 'True':
len_head_dic = struct.unpack('i', client.recv(4))[0]
head_dic = json.loads(client.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 = client.recv(1024)
len_data += len(data)
md5.update(data)
f.write(data)
data_md5 = md5.hexdigest()
if data_md5 == file_md5:
print('下载成功.')
return True
else:
print('下载失败.')
else:
print('输入错误,请重新输入.')
def run(): # 主循环
if login():
print('登陆成功~~~~~~~')
print('欢迎来到主页面~~~~~~')
while 1:
print('[1]上传\t[2]下载\t[3]退出')
choice = input('请输入选项:').strip()
client.send(choice.encode('utf-8'))
if choice == '1':
up()
elif choice == '2':
down()
elif choice == '3':
print('正在退出...')
break
else:
print('输入错误,请重新输入')
else:
print('登录失败,正在退出....')
if __name__ == '__main__':
run()
FTP上传下载文件(函数简易版)的更多相关文章
- java客户端调用ftp上传下载文件
1:java客户端上传,下载文件. package com.li.utils; import java.io.File; import java.io.FileInputStream; import ...
- FTP上传下载文件(面向对象版)
# 服务端 import socketserver import os import json import hashlib import struct class MySocketServer(so ...
- 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 ...
随机推荐
- day65--mysql数据库--索引、慢日志、分页
---恢复内容开始--- 一.索引 (一)介绍: 数据库中专门用于帮助用户快速查找数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置吗,然后直接获取. (二)作用: ...
- 攻防世界--no-strings-attached
测试文件:https://adworld.xctf.org.cn/media/task/attachments/5d4117b968684b9483d0d4464e0a6fea 这道题要使用到gdb文 ...
- Linux学习笔记之目录配置
一.目录配置 相关目录说明 /bin 二进制文件 /boot 系统启动文件(内核的初始化文件等) /dev 设备文件(硬盘等) /e ...
- php pdo_mysql扩展安装
本文内容是以 CentOS 为例,红帽系列的 Linux 方法应该都是如此,下面就详细说明步骤,在这里严重鄙视哪些内容??隆⑺档脑悠咴影说挠泄 PDO 编译安装的文章. 1.进入 PHP 的软件包 p ...
- windows10安装nodejs 10和express 4
最进做一个个人博客系统,前端用到了semanticUI,但是要使用npm工具包,所以需要安装nodejs,nodejs自带npm 下载 去官网下载自己系统对应的版本,我的是windows:下载 可以在 ...
- python发行包 IDE
https://blog.csdn.net/qq_38188725/article/details/80624004 https://blog.csdn.net/qq_38188725/article ...
- rabbitmq 结构体
amqp_basic_properties_t props; props._flags = AMQP_BASIC_CONTENT_TYPE_FLAG | AMQP_BASIC_DELIVERY_MOD ...
- GO string 的学习
1.replace func Replace(s, old, new string, n int) string s:原来的字符串 old: 要被替换的久的字符串 new string:要替换旧字符串 ...
- Python3.5-20190504-自我笔记浅拷贝和深拷贝
浅拷贝和深拷贝 (自己一直搞不懂的) 1.直接赋值(把一个变量直接赋值给另一个变量),他们指向同一个内存的数据(右边的图不知道怎么画,就直接截图过来了.将就看看) ------------- 2.使用 ...
- 【挖坟】HDU3205 Factorization
分圆多项式 问题在于精度貌似出了一些奇怪的问题... [输出也写的有问题QAQ] 完全不会处理了 加上全网没有题解T^T 挖个坑以后补.. #include<cstdio> #includ ...