20231304 2023-2024-2 《Python程序设计》实验三报告
课程:《Python程序设计》
班级: 2313
姓名: 王星婷
学号:20231304
实验教师:王志强
实验日期:2024年4月17日
必修/选修: 公选课
1.实验内容
创建服务端和客户端,服务端在特定端口监听多个客户请求。客户端和服务端通过Socket套接字(TCP/UDP)进行通信。
(1)创建服务端和客户端,选择一个通信端口,用Python语言编程实现通信演示程序;
(2)要求包含文件的基本操作,例如打开和读写操作。
(3)要求发送方从文件读取内容,加密后并传输;接收方收到密文并解密,保存在文件中。
(4)程序代码托管到码云。
2. 实验过程和结果
服务端
使用DES算法进行加密和解密
des_encrypt函数用于加密输入的字符串。它接受两个参数:待加密的字符串和密钥。首先,它设置了密钥和初始化向量(IV),然后创建了一个DES对象,使用CBC模式和PKCS5填充方式。接着,它对输入字符串进行加密,并将加密后的结果转换为十六进制表示,并将其解码为字符串后返回。
des_descrypt函数用于解密密文。它接受两个参数:待解密的密文和密钥。它的操作与加密函数类似,但是将十六进制表示的密文解码后再进行解密操作,并返回解密后的明文字符串。
在块中,首先使用函数将字符串"hello, world!"加密,并打印出加密后的密文。然后使用函数对密文进行解密,并打印出解密后的明文。
def des_encrypt(s, KEY):
secret_key = KEY
iv = secret_key
k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5)
en = k.encrypt(s, padmode=PAD_PKCS5)
return binascii.b2a_hex(en).decode()
def des_descrypt(s, KEY):
secret_key = KEY
iv = secret_key
k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5)
de = k.decrypt(binascii.a2b_hex(s), padmode=PAD_PKCS5)
return de.decode()
if __name__ == "__main__":
ciphertext = des_encrypt("hello, world!", "1234567890")
print("密文:",ciphertext)
plaintext = des_descrypt(ciphertext, "1234567890")
print("解密后的明文:", plaintext)
一个简单的TCP服务器,接收来自客户端的连接并与之通信
import socket
from DesModule import des_descrypt,des_encrypt
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind(("192.168.3.20", 2024))
s.listen()
conn, address = s.accept()import socket
data = conn.recv(1024)
print("从客户端收到的信息为:", data.decode())
conn.sendall("hahaha".encode())
s.close()
tcpserver = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcpserver.bind(("192.168.3.20", 2024))
tcpserver.listen(5)
while True:
conn, addr = tcpserver.accept()
print(conn)
while True:
try:
data = conn.recv(1024)
print(data.decode("utf-8"))
# ret_data = "收到!"
ret_data = input("请回复:")
conn.send(ret_data.encode('utf-8'))
except Exception:
break
conn.close()
客户端
import socket
import os
from DesModule import *
file1 = open("haha", "r+")#"w"
file1.write("haihaihai")
file1.seek(0)
cryptostring = file1.readline()
print(cryptostring)
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.connect(("192.168.3.20", 8022))
# s.connect(("192.168.43.158", 6000))
s.sendall(cryptostring.encode())
data = s.recv(1024)
print("从服务器接收的数据为:",data.decode())
s.close()
import socket
tcpclient = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcpclient.connect(("192.168.3.20", 8022))
while True:
while True:
data = input('>>>').strip()
tcpclient.send(data.encode('utf-8'))
ret = tcpclient.recv(1024)
print(ret.decode('utf-8'))
tcpclient.close()
3. 实验过程中遇到的问题和解决过程
- 问题1:找不到IP地址
- 问题1解决方案:在cmd中输入ipconnfig即可找到
- 问题2:服务端和客户端无法连接
- 问题2解决方案:电脑连接同一WLAN更容易连接成功,需要多试几次
其他(感悟、思考等)
实验好难
参考资料
实验三Socket编程技术
chatgpt