学号 2019-2020-2 《Python程序设计》实验3报告
课程:《Python程序设计》
班级: 1934
姓名: 李宇凡
学号:20193404
实验教师:王志强
实验日期:2020年5月23日
必修/选修: 公选课
1.实验内容:
(一)实验内容
创建服务端和客户端,服务端在特定端口监听多个客户请求。客户端和服务端通过Socket套接字(TCP/UDP)进行通信。
(二)实验要求
(1)创建服务端和客户端,选择一个通信端口,用Python语言编程实现通信演示程序。
(2)要求包含文件的基本操作,例如打开和读写操作。
(3)要求发送方从文件读取内容,加密后并传输;接收方收到密文并解密,保存在文件中。
(4)程序代码托管到码云。
2. 实验过程及结果:
实验思路:
利用socket技术完成简单的服务器端和客户端的交流,要求中加入文件操作和文件加密,需在交流的基础上进行读取,加密,解密,写入文件。
客户端
import socket
import os
import base64
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('127.0.0.1', 8005))
str1 = input("请输入要传输的文件名:")
s.sendall(str1.encode())
os.chdir(r"E:\client\download")
file = open(str1, 'r')
text = file.read()
text = text.encode('utf-8')
encode_text = base64.b32encode(text)
s.sendall(encode_text)
file.close()
data = s.recv(1024)
print("来自 ('127.0.0.1') 的信息:", data.decode())
s.sendall("收到".encode())
name = s.recv(1024)
print("来自 ('127.0.0.1') 的文件:", name.decode())
data = s.recv(1024)
f = open("reply.txt", "w")
f.write(data.decode())
f.close()
print("文件内容已加密发送")
s.sendall("已成功接收,中断连接!".encode())
s.close()
服务端
import socket
import os
import base64
os.chdir(r"E:\client\download")
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind(('127.0.0.1', 8005))
s.listen()
conn, address = s.accept()
name = conn.recv(1024)
print("来自", address, "的文件:", name.decode())
data = conn.recv(1024)
f = open("receive.txt", "w")
data1 = base64.b32decode(data)
f.write(data1.decode())
f.close()
print("来自", address, "加密的信息:", data.decode(), "解密后已保存为receive.txt")
conn.sendall("服务器已经收到了数据内容,准备传输文件,注意接收!".encode())
data1 = conn.recv(1024)
conn.sendall("reply.txt".encode())
f = open("receive.txt", "r")
data1 = f.read()
conn.sendall(data1.encode())
f.close()
data1 = conn.recv(1024)
print("来自", address, "的信息", data1.decode())
s.close()
3. 实验过程中遇到的问题和解决过程:
一、可能会遇到电脑中文件阻止连接的情况
可以关闭防火墙对其的监视
二、不能连接
调整路径
三、无效的路径
不要指定文件,要指定于文件夹
4.其他(感悟、思考等)
1、base64的简洁性和便捷性是长处,但容易出现漏洞。
2、socket技术完美地使得服务器端和客户端结合,良好的互动性。
3、需要一个优秀的代码风格。