20183429 张少旋 《Python程序设计》实验三 报告

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逐字符转换成字节,再传输给加密部分进行加密,并在加密后封装为统一格式传输。

参考资料

蓝墨云班课

百度

 

posted @ 2020-07-08 11:18  张少旋  阅读(195)  评论(0编辑  收藏  举报