初级版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万个以上,且包 ...
随机推荐
- maven项目报错--Cannot change version of project facet Dynamic Web Module to 3.0 Error in Eclipse
错误原因: 使用ecplise构建的maven骨架默认支持的是web2.3的版本,当使用这个创建3.0版本的web项目时则会报这样的错误: Cannot change version of proje ...
- 【wireshark】插件开发(二):Lua插件开发介绍
1. Wireshark对Lua的支持 本节相关内容可参考Wireshark开发指南第10章”Lua Support in Wireshark”. Wireshark集成了Lua解释器,以支持Lua脚 ...
- J06-Java IO流总结六 《 BufferedReader和BufferedWriter 》
1. 概念简介 与字节缓冲流BufferedInputStream和BufferedOutputStream对应的,我们还有字符缓冲流BufferedReader和BufferedWriter,顾名思 ...
- (转)python中math模块常用的方法整理
原文:https://www.cnblogs.com/renpingsheng/p/7171950.html#ceil ceil:取大于等于x的最小的整数值,如果x是一个整数,则返回x copysig ...
- Spring Boot 项目发布到 Tomcat 服务器
第 1 步:将这个 Spring Boot 项目的打包方式设置为 war.<packaging>war</packaging> SpringBoot 默认有内嵌的 tomcat ...
- Dubbo-使用Maven构建Dubbo服务的可执行jar包
一.为什么要构建Dubbo服务的可执行jar包? 1.1 Dubbo服务运行方式比较 ✎使用Servlet容器运行(Tomcat.Jetty等) ---不可取 --缺点:增加复杂性(多了容器的端口) ...
- 在CentOS上装Redis
Redis官网 $ wget http://download.redis.io/releases/redis-3.2.5.tar.gz $ tar xzf redis-.tar.gz $ cd red ...
- jquery.lazyload插件实现图片延迟加载
jquery.lazyload是一个实现图片延迟加载的jQuery 插件,它可以延迟加载长页面中的图片.在浏览器可视区域外的图片在初始状态下不会被载入,直到用户将页面滚动到它们所在的位置. 1.引入j ...
- Notepad++软件的下载与安装步骤(图文详解)
不多说,直接上干货! 这款软件非常好用!!! 1.下载Notepad++软件 Notepad++非常好用,想要安装首先我们要下载(废话)~ 百度搜索“Notepad++”直接就可以找到主页: 主页 ...
- SQL脚本文件执行器
处于项目需求,需要能够批量执行SQL脚本文件,需要由前台页面操作触发执行. 查找相关资料,发现 Ant 提供了 SQLExec 组件可以支持SQL文件的执行,测试效果不错. 以下是对 SQLExec ...