20183429 张少旋 《Python程序设计》实验三 报告
课程:《Python程序设计》
班级: 1834
姓名: 张少旋
学号:20183429
实验教师:王志强老师
必修/选修: 选修
1.实验内容
(1)创建服务端和客户端,选择一个通信端口,用Python语言编程实现通信演示程序;
(2)要求包含文件的基本操作,例如打开和读写操作。
(3)要求发送方从文件读取内容,加密后并传输;接收方收到密文并解密,保存在文件中。
2.实验过程及结果
本实验要求设计服务端和客户端,使得发送方能够加密向接收端发送文件,使用RSA模块进行加密,可以自主
选择文件进行发送,接收方能够解密并自动保存。
代码如下
发送方代码:
import socket
import rsa
with open('public.pem', 'r') as f:
pubkey = rsa.PublicKey.load_pkcs1(f.read().encode())
with open('private.pem', 'r') as f:
privkey = rsa.PrivateKey.load_pkcs1(f.read().encode())
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('127.0.0.1', 8001))
name = input('请输入要传输的文件名:')
f0 = open(name,mode='r',encoding='utf-8')
a = f0.readlines()for row in a:
bytes(row,encoding = ('utf-8'))
info = rsa.encrypt(row.encode(),pubkey)
print(info)
s.sendall(info)
data = s.recv(1024)print(data.decode())
s.close()
接收方代码:
import socketimport rsa
(pubkey,privkey) = rsa.newkeys(512)
pub = pubkey.save_pkcs1()
pri = privkey.save_pkcs1()with open('pubkey.pem',mode = 'wb') as f,open('privkey.pem',mode = 'wb') as f1:
f.write(pub)
f1.write(pri)
pubkey = rsa.PublicKey.load_pkcs1(pub)with open('private.pem', 'r') as prf:
pri = prf.read()
privkey = rsa.PrivateKey.load_pkcs1(pri)
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.bind(('127.0.0.1',8001))
s.listen()with open('serve_got.txt', 'w') as f:
pass
conn,address = s.accept()
data = conn.recv(1024)
info = rsa.decrypt(data, privkey).decode()
print(info)with open('serve_got.txt', mode='a') as f:
f.write(info)
f.close()
conn.sendall((bytes('已收到文件:',encoding = ('utf-8')) + bytes(info,encoding = ('utf-8'))))
s.close()
3. 实验过程中遇到的问题和解决过程
问题:无法加密
导入了RSA加密模块,但在加密的过程中,程序指出需要将导入的文件信息改为字节,而不是字符串,在加入了转换代码
后,还是转换不了,需要指定的格式,用了decode、encode等,还是出现了问题。
解决方法:
使用格式转换的代码,将txt逐字符转换成字节,再传输给加密部分进行加密,并在加密后封装为统一格式传输。
参考资料
蓝墨云班课
百度