介绍 🍀
在上一篇中写了最基本版的socket服务端和客户端 , 即仅能通信一次后就自动关闭了 , 显然实际应用中可不是这样的 , 那就来写一个像QQ一样的聊天程序吧
TCP实现 🍀
因为TCP是有链接的 , 这就导致只能有一个服务端 , 但是可以有多个客户端
tcpqq_server.py
import socket
sock = socket.socket()
sock.bind(('127.0.0.1', 8080))
sock.listen(5)
# 实现链接循环
while True:
print("Watiting for the link...")
conn, addr = sock.accept()
print("Your friend {} is online...".format(addr))
# 实现通信循环
while True:
messages = conn.recv(1024)
print("Messages from [{}]:{}".format(addr, messages.decode('utf-8')))
if messages == b'q':
break
else:
while True:
data = input("Please input the messages to be sent:").strip().encode('utf-8')
# 注意发送的内容不能为空,否则接收方就会一直等下去
if not data:
print("Can't be empty...")
continue
conn.send(data)
break
print("Your friend {} is offline...".format(addr))
conn.close()
sock.close()
tcpqq_client.py
import socket
sock = socket.socket()
sock.connect(('127.0.0.1', 8080))
# 实现通信循环
while True:
messages = input("Please input your messages to be sent:").strip().encode('utf-8')
# 注意发送的内容不能为空,否则接收方就会一直等下去
if not messages:
print("Can't be empty...")
continue
elif messages == b'q':
break
else:
sock.send(messages)
data = sock.recv(1024)
print("Messages from [{}]:{}".format(('127.0.0.1', 8080), data.decode('utf-8')))
sock.close()
当然实际应用中是不会用TCP来完成的 , 而是用UDP , 这里只是模拟 , 并且以上还有有问题没有解决的 , 比如如果发送的消息大于1024字节 , 那么就不能完整接收信息了 , 后续再进行处理
TCP版本的服务端可以允许同时连入5个客户端 , 值得注意的是并不是同时连入 , 按照顺序排队 , 只有前面的人说完了会连入后序的客户端
UDP实现 🍀
以为UDP是无链接的 , 所以它可以实现想跟谁说话就跟谁说话
udpqq_server.py
import socket
sock = socket.socket(type=socket.SOCK_DGRAM)
sock.bind(('127.0.0.1', 8080))
# 实现通信循环
while True:
data, addr = sock.recvfrom(1024)
print("Receive a message from {}:{}".format(addr, data.decode('utf-8')))
if data == b'q':
break
while True:
messages = input("Please input the messages to be sent:").strip().encode('utf-8')
if not messages:
print("Can't be empty...")
continue
sock.sendto(messages, addr)
break
sock.close()
udpqq_client.py
import socket
sock = socket.socket(type=socket.SOCK_DGRAM)
# 实现通信循环
while True:
messages = input("Please input your messages to be sent:").strip().encode('utf-8')
if not messages:
print("Can't be empty...")
continue
elif messages == b'q':
break
else:
sock.sendto(messages, ('127.0.0.1',8080))
data, addr = sock.recvfrom(1024)
print("Receive a message from {}:{}".format(addr, data.decode('utf-8')))
sock.close()
利用UDP实现才更接近现实 , 我们只需要知道他的ip和端口 , 我们就可以跟他讲话 , 在他即可以是服务端 , 也可以是客户端 , 不过必须注意接收和发送流程的问题
以上两种实现方式 , 都只是最基础的版本 , 在UDP中我们可以将所有人的ip和端口放到一个字典里或者其他存储里 , 利用ip和端口就可以实现跟所有人进行聊天了