110
社区成员
发帖
与我相关
我的任务
分享课程:《Python程序设计》
班级: 2324
姓名: 马成栋
学号:20232429
实验教师:王志强
实验日期:2024年4月22日
必修/选修: 公选课
创建服务端和客户端,服务端在特定端口监听多个客户请求。客户端和服务端通过Socket进行通信.
(1)创建服务端和客户端,选择一个通信端口,用Python语言编程实现通信演示程序;
(2)要求包含文件的基本操作,例如打开和读写操作。
(3)要求发送方从文件读取内容,加密后并传输;接收方收到密文并解密,可以进行实时通讯
import socket
from Crypto.Cipher import AES
from Crypto.Util.Padding import unpad
def decrypt(encrypted_text, key):
cipher = AES.new(key, AES.MODE_ECB)
decrypted_text = cipher.decrypt(encrypted_text)
unpadded_text = unpad(decrypted_text, AES.block_size)
return unpadded_text.decode('utf-8')
key = b'0123456789abcdef'
tcpserver = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcpserver.bind(("192.168.1.101", 2025))
tcpserver.listen(10)
while True:
conn, addr = tcpserver.accept()
print(conn)
while True:
try:
data = conn.recv(1024)
decrypted_data = decrypt(data, key)
print(decrypted_data)
ret_data = "收到!"
ret_data = input("请回复:")
conn.send(ret_data.encode('utf-8'))
except Exception:
break
conn.close()
import socket
from Crypto.Cipher import AES
from Crypto.Util.Padding import pad, unpad
def encrypt(plain_text, key):
cipher = AES.new(key, AES.MODE_ECB)
padded_text = pad(plain_text.encode('utf-8'), AES.block_size)
encrypted_text = cipher.encrypt(padded_text)
return encrypted_text
def decrypt(encrypted_text, key):
cipher = AES.new(key, AES.MODE_ECB)
decrypted_text = cipher.decrypt(encrypted_text)
unpadded_text = unpad(decrypted_text, AES.block_size)
return unpadded_text.decode('utf-8')
key = b'0123456789abcdef'
tcpclient = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcpclient.connect(("192.168.1.100", 2024))
while True:
while True:
data = input('>>>').strip()
encrypted_data = encrypt(data, key)
tcpclient.send(encrypted_data)
ret = tcpclient.recv(1024)
decrypted_ret = decrypt(ret, key)
print(decrypted_ret)
tcpclient.close()



