Professional Documents
Culture Documents
python
By Diego Caraballo | 20:275 Comentarios
Los socket se pueden configurar para que actúen como un servidor y así poder escuchar
los mensajes entrantes, o conectarse a otras aplicaciones como clientes. Luego de que
ambos extremos de un socket TCP/IP están conectados, la comunicación es bidireccional.
Estas primeros ejemplos que explico, fueron creados en "localhost" en un PC con sistema
Linux (Ubuntu).
Cliente - Servidor
Este sencillo código de ejemplo (Servidor.py), recibe mensajes entrantes y los ecos de vuelta
al remitente. Esto se hace creando un socket TCP/IP:
?
1
#!/usr/bin/python
2 # -*- coding: utf-8 -*-
3
4 # Programa Servidor
5 # www.pythondiario.com
6
7 import socket
8 import sys
9
# Creando el socket TCP/IP
10 sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
11
Luego el método bind() es utilizado para asociar un socket a una dirección de servidor. En
este caso, la dirección es un localhost (dirección actual) y el número de puerto es 10000.
El método accept() acepta una conexión entrante (un cliente) y el método listen() pone al
socket en modo servidor.
El método accept() nos devuelve una conexión abierta entre el servidor y el cliente, junto
con la dirección del cliente. Los datos de la conexión se leen con el método recv() y se
transmiten con el método sendall().
1 while True:
2 # Esperando conexion
3 print >>sys.stderr, 'Esperando para conectarse'
connection, client_address = sock.accept()
4
5 try:
6 print >>sys.stderr, 'concexion desde', client_address
7
8 # Recibe los datos en trozos y reetransmite
9 while True:
data = connection.recv(19)
10 print >>sys.stderr, 'recibido "%s"' % data
11 if data:
12 print >>sys.stderr, 'enviando mensaje de vuelta al cliente'
13 connection.sendall(data)
14 else:
print >>sys.stderr, 'no hay mas datos', client_address
15 break
16
17 finally:
18 # Cerrando conexion
19 connection.close()
20
21
22
Cuando se termina la comunicación con un cliente, la conexión debe ser cerrada con
el método close(). Nuestro ejemplo utiliza try:finally para asegurar que la conexión sea
cerrada igual en caso de un error.
El código para el programa cliente (Cliente.py) utiliza el socket diferente a como lo hace
elServidor. En lugar de unirse a un puerto para escuchar conexiones, utiliza el método
connect()para fijar una conexión remota.
1 #!/usr/bin/python
2 # -*- coding: utf-8 -*-
3
# Programa Cliente
4 # www.pythondiario.com
5
6 import socket
7 import sys
8
9 # Creando un socket TCP/IP
10 sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
11
# Conecta el socket en el puerto cuando el servidor esté escuchando
12 server_address = ('localhost', 10000)
13 print >>sys.stderr, 'conectando a %s puerto %s' % server_address
14 sock.connect(server_address)
15
16
Después que la conexión esté establecida, la información puede ser enviada con el método
sendall() y recibida con el método recv(), igual que el servidor.
1
2 try:
3
4 # Enviando datos
5 message = 'Este es el mensaje. Se repitio.'
print >>sys.stderr, 'enviando "%s"' % message
6
sock.sendall(message)
7
8 # Buscando respuesta
9 amount_received = 0
10 amount_expected = len(message)
11
12 while amount_received < amount_expected:
data = sock.recv(19)
13 amount_received += len(data)
14 print >>sys.stderr, 'recibiendo "%s"' % data
15
16 finally:
17 print >>sys.stderr, 'cerrando socket'
18 sock.close()
19
Finalmente, cuando el mensaje es enviado, y la copia recibida, la conexión se cierra para
dejar libre el puerto.
Ejecutaremos los programas en dos ventanas diferentes para que puedan comunicarse entre
si. Esta es la salida impresa del Servidor:
Salida impresa del Servidor
Luego hice las pruebas de forma inversa. El PC con Windows 7 actuó como Servidor y el PC
con Windows XP funcionó como Cliente.
Espero esta entrada sea de ayuda para iniciarse con los socket en python. Cualquier duda
o sugerencia pueden dejarlas al final de la entrada.