Aprimorando a Serialização de Dados para Comunicação
Nesta etapa, aprimoraremos a comunicação entre o cliente e o servidor serializando e deserializando dados para transmissão.
- Modifique o código
server.py para incluir a serialização e deserialização de dados.
## 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())
- Modifique o código
client.py para incluir a serialização e deserialização de dados.
## 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())
Execute esses dois arquivos ao mesmo tempo e clique em "Split Terminal" para conseguir isso. As informações abaixo devem ser exibidas no seu terminal:
labex:project/ $ python server.py
Connected by ('127.0.0.1', 40082)
labex:project/ $ python client.py
Received HELLO, SERVER