Verbesserung der Daten-Serialisierung für die Kommunikation
In diesem Schritt werden wir die Kommunikation zwischen Client und Server verbessern, indem wir die Daten für die Übertragung serialisieren und deserialisieren.
- Ändern Sie den Code in
server.py
, um die Daten-Serialisierung und -Deserialisierung zu integrieren.
## server.py
import socket
import pickle
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_socket.bind(('127.0.0.1', 8888))
server_socket.listen(1)
connection, address = server_socket.accept()
with connection:
print('Connected by', address)
while True:
data = connection.recv(1024)
if not data:
break
deserialized_data = pickle.loads(data)
processed_data = deserialized_data.upper()
connection.sendall(processed_data.encode())
- Ändern Sie den Code in
client.py
, um die Daten-Serialisierung und -Deserialisierung zu integrieren.
## client.py
import socket
import pickle
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client_socket.connect(('127.0.0.1', 8888))
data_to_send = pickle.dumps('Hello, server')
client_socket.sendall(data_to_send)
received_data = client_socket.recv(1024)
print('Received', received_data.decode())
Führen Sie diese beiden Dateien gleichzeitig aus und klicken Sie auf "Split Terminal", um dies zu erreichen. Folgende Informationen sollten auf Ihrem Terminal angezeigt werden:
labex:project/ $ python server.py
Connected by ('127.0.0.1', 40082)
labex:project/ $ python client.py
Received HELLO, SERVER