初级版python登录验证,上传下载文件加MD5文件校验
服务器端程序
import socket
import json
import struct
import hashlib
import os def md5_code(usr, pwd):
ret = hashlib.md5(usr.encode())
ret.update(pwd.encode())
return ret.hexdigest() def login():
recv_msg = conn.recv(1024).decode()
msg_dic = json.loads(recv_msg)
with open('user_msg', 'r', encoding='utf-8') as f1, \
open('user_msg', 'a', encoding='utf-8') as f2:
for con in f1:
con_li = con.strip().split()
if con_li[0] == msg_dic['username'] and con_li[1] == md5_code(msg_dic['username'], msg_dic['password']):
flag = json.dumps({'flag': 1})
conn.send(flag.encode())
return {'flag': 1}
else:
flag = json.dumps({'flag': 0})
conn.send(flag.encode())
content = msg_dic['username'] + '\t' + md5_code(msg_dic['username'], msg_dic['password']) + '\n'
f2.write(content)
return {'flag': 0} def upload():
dic_len = conn.recv(4)
dic_size = struct.unpack('i', dic_len)[0]
file_info = json.loads(conn.recv(dic_size))
f1 = open(file_info['filename'], 'wb')
md5_data = hashlib.md5() while file_info['filesize'] > 0:
# 在最后接收文件不足2048时接收精准字节,避免与后面发送的数据发生粘包
if 0 < file_info['filesize'] < 1204:
content = conn.recv(file_info['filesize'])
else:
content = conn.recv(2048)
md5_data.update(content)
f1.write(content)
# 每次减去实际接收的文件长度可以避免tcp协议拆包时实际接收到的数据没有2048而导致接收数据不完整
file_info['filesize'] -= len(content) f1.close() # 获得校验后的md5值
md5sum = md5_data.hexdigest()
# 接收客户端校验后的md5值
recv_md5 = conn.recv(32).decode() if md5sum == recv_md5:
print('校验成功')
return {'flag': 1}
else:
print('校验失败')
return {'flag': 0} def download():
dic_len = conn.recv(4)
dic_size = struct.unpack('i', dic_len)[0]
file_info = json.loads(conn.recv(dic_size))
file_size = os.path.getsize(file_info['filename']) dir_list = os.listdir('.')
dfile_info = {'filesize': file_size, 'operate': 'download', 'dir_list': dir_list}
file_dic = json.dumps(dfile_info).encode()
file_len = struct.pack('i', len(file_dic)) # 发送文件信息
conn.send(file_len)
conn.send(file_dic) f1 = open(file_info['filename'], 'rb')
md5_data = hashlib.md5() while file_size:
content = f1.read(2048)
md5_data.update(content)
file_size -= len(content)
conn.send(content)
f1.close() md5sum = md5_data.hexdigest()
print(md5sum)
conn.send(md5sum.encode())
return {'flag': 1} server = socket.socket()
server.bind(('127.0.0.1', 8001))
server.listen(5)
conn, addr = server.accept() login_ret = login()
if login_ret['flag']:
while login_ret['flag']:
recv_cmd = conn.recv(1024).decode()
cmd_dic = json.loads(recv_cmd)
if cmd_dic['cmd'] == '':
print('上传文件中')
upload()
elif cmd_dic['cmd'] == '':
print('下载文件中')
download()
elif cmd_dic['cmd'] == '':
break
else:
print('请重新登录') conn.close()
server.close()
客户端程序
import os
import json
import socket
import struct
import hashlib
# import time def login():
usr = input('请输入用户名:')
pwd = input('请输入密码:')
usr_info_dic = {'username': usr, 'password': pwd, 'operate': 'login'}
usr_info = json.dumps(usr_info_dic).encode()
client.send(usr_info)
ret = client.recv(1024).decode()
flag_dic = json.loads(ret)
if flag_dic['flag']:
print('登录成功')
return {'flag': 1}
else:
print('登录失败')
return {'flag': 0} def upload():
# F:\test.mp4
file_path = input('请输入文件路径:')
file_size = os.path.getsize(file_path)
file_name = os.path.basename(file_path)
file_info = {'filesize': file_size, 'filename': file_name, 'operate': 'upload'}
file_dic = json.dumps(file_info).encode()
file_len = struct.pack('i', len(file_dic))
# 发送文件信息
client.send(file_len)
client.send(file_dic) total_size = file_size
# 打开文件准备上传文件
md5_data = hashlib.md5() f1 = open(file_path, 'rb')
while file_size:
content = f1.read(2048*10)
md5_data.update(content)
file_size -= len(content)
client.send(content)
print('\r已上传%s%%' % int((1 - file_size / total_size) * 100), end='')
print('上传成功!')
f1.close() md5sum = md5_data.hexdigest()
print(md5sum)
# time.sleep(0.1)
client.send(md5sum.encode()) return {'flag': 1} def download():
# F:\test.mp4
file_name = input('请输入文件名:')
file_info = {'filename': file_name, 'operate': 'download'}
file_dic = json.dumps(file_info).encode()
file_len = struct.pack('i', len(file_dic))
# # 发送文件信息
client.send(file_len)
client.send(file_dic) dic_len = client.recv(4)
dic_size = struct.unpack('i', dic_len)[0]
dfile_info = json.loads(client.recv(dic_size)) md5_data = hashlib.md5()
for dir_index, dir_name in enumerate(dfile_info['dir_list']):
print(dir_index, dir_name) total_size = dfile_info['filesize']
f1 = open('down' + file_name, 'wb')
while dfile_info['filesize'] > 0:
# 在最后接收文件不足2048时接收精准字节,避免与后面发送的数据发生粘包
if 0 < dfile_info['filesize'] < 1204:
content = client.recv(dfile_info['filesize'])
else:
content = client.recv(2048)
md5_data.update(content)
f1.write(content)
dfile_info['filesize'] -= len(content)
print('\r已下载%s%%' % int((1-dfile_info['filesize'] / total_size) * 100), end='')
f1.close() md5sum = md5_data.hexdigest()
# print('\n', md5sum) recv_md5 = client.recv(32).decode() # print(recv_md5)
if md5sum == recv_md5:
print('校验成功')
return {'flag': 1}
else:
print('校验失败')
return {'flag': 0}
# print('下载成功!')
# return {'flag': 1} def choose_cmd():
print('''
1.上传文件
2.下载文件
3.退出上传下载文件
''')
cmd = input('请输入序号选择相应操作')
dic = {'cmd': cmd}
cmd_dic = json.dumps(dic).encode()
client.send(cmd_dic)
return dic client = socket.socket()
# client.connect(('192.168.13.13', 8001))
client.connect(('127.0.0.1', 8001)) login_ret = login()
if login_ret['flag']:
while login_ret['flag']:
cmd_ret = choose_cmd()
if cmd_ret['cmd'] == '':
upload()
elif cmd_ret['cmd'] == '':
download()
elif cmd_ret['cmd'] == '':
break
else:
print('输入的序号有误')
else:
print('请重新登录') client.close()
初级版python登录验证,上传下载文件加MD5文件校验的更多相关文章
- 使用cmd命令行方式登录ftp上传下载数据
部分用户在使用ftp工具登录空间上传下载过程中经常会遇到各种问题,如主动模式,被动模式,以及其他导致无法登陆ftp .上传数据.下载数据的问题,这时候不妨使用一下命令行方式.命令行下可以避免很多由于f ...
- python实现socket上传下载文件-进度条显示
在python的socket编程中,可以实现上传下载文件,并且在下载的时候,显示进度条,具体的流程如下图所示: 1. 服务器端代码如下: [root@python 519]# cat server.p ...
- python flask解决上传下载的问题
记录瞬间 最近为了解决一些新的需求,简单介入了flask对文件的上传和下载的方法,并分别使用python和curl模拟发送 代码: #! /usr/bin/env python3 # coding:u ...
- AzCopy – 上传/下载 Windows Azure Blob 文件
在我们收到的请求中,有一个频繁出现的请求是提供一种能在 Windows Azure Blob 存储与其本地文件系统之间轻松上传或下载文件的方法.一年半前, 我们很高兴地发布了 AzCopy, Wind ...
- 用SpringMVC实现的上传下载方式二(多文件上传)
参考来源: http://blog.csdn.net/qq_32953079/article/details/52290208 1.导入相关jar包 commons-fileupload.j ...
- python用ftplib上传下载中文报错解决
python中的中文编码一直以来都是一个极为头大的问题,经常抛出编码转换的异常,python中的str和unicode到底是一个什么东西呢?在python中提到unicode,一般指的是unicode ...
- python 实现远端ftp文件上传下载
python 实现ftp上传下载 * 脚本需要传入两个参数,参数1为需要从远端ftp站点下载文件名称,参数2为已知需要下载的文件md5值,文件下载完成后会自动进行md5值校验 * 运行示例 [root ...
- javaEE(14)_文件上传下载
一.文件上传概述 1.实现web开发中的文件上传功能,需完成如下二步操作: •在web页面中添加上传输入项•在servlet中读取上传文件的数据,并保存到本地硬盘中. 2.如何在web页面中添加上传输 ...
- Java Web 项目的文件/文件夹上传下载
需求: 支持大文件批量上传(20G)和下载,同时需要保证上传期间用户电脑不出现卡死等体验: 内网百兆网络上传速度为12MB/S 服务器内存占用低 支持文件夹上传,文件夹中的文件数量达到1万个以上,且包 ...
随机推荐
- Python面向对象(类的成员之属性)
day24 类的成员之属性 class Foo(): def bar(self): print("bar") @property def per(self): ') return ...
- 基于SWOOLE的分布式SOCKET消息服务器架构
消息服务器使用socket,为避免服务器过载,单台只允许500个socket连接,当一台不够的时候,扩充消息服务器是必然,问题来了,如何让链接在不同消息服务器上的用户可以实现消息发送呢? 要实现消息互 ...
- 小型Http服务器
HTTP又叫做超文本传输协议,现如今用的最多的版本是1.1版本.HTTP有如下的特点: 支持客户/服务器模式(C/S或B/S) 简单快速:基于请求和响应,请求只需传送请求方法和请求路径 灵活:HTTP ...
- Zookeeper原理分析之存储结构TxnLog
Zookeeper事物日志文件用于记录事物操作,如添加,删除节点等等,都会在事务日志中记录一条记录.下面我们就详细分析一下txnLog事务日志文件. txnLog事务日志文件文件由三部分组成: 日志文 ...
- django -admin 源码解析
admin源码解析 单例模式 单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在.当你希望在整个系统中,某个类只能出现一个实例时,单 ...
- python Snakes 库安装
SNAKES : A A Flexible High-Level Petri Nets Library SNAKES是python一个可以用于Petri网的库 python2安装SNAKES库: 在 ...
- git问题--Push rejected: Push to origin/master was rejected
解决git问题 Push rejected: Push to origin/master was rejected 意思是git拒绝合并两个不相干的东西 此时你需要在打开Git Bash,然后进入相应 ...
- 【C#小知识】C#中一些易混淆概念总结(五)---------继承 分类: C# 2014-02-06 22:05 1106人阅读 评论(0) 收藏
目录: [C#小知识]C#中一些易混淆概念总结--------数据类型存储位置,方法调用,out和ref参数的使用 [C#小知识]C#中一些易混淆概念总结(二)--------构造函数,this关键字 ...
- php 实现繁体转简体代码效率对比
第一份代码: <?php Header("Content-Type:text/html;charset=utf-8"); function microtime_float() ...
- 【转】Spark源码分析之-deploy模块
原文地址:http://jerryshao.me/architecture/2013/04/30/Spark%E6%BA%90%E7%A0%81%E5%88%86%E6%9E%90%E4%B9%8B- ...