首先我们写一个客户端:
import socket
# 客户端 发送一个数据,再接收一个数据
client = socket.socket(socket.AF_INET,socket.SOCK_STREAM) #声明socket类型,同时生成链接对象
client.connect(('localhost',6969)) #建立一个链接,连接到本地的6969端口
while True:
msg = input('>>:').strip() #strip默认取出字符串的头尾空格
client.send(msg.encode('utf-8')) #发送一条信息 python3 只接收btye流
data = client.recv(1024) #接收一个信息,并指定接收的大小 为1024字节
print('recv:',data.decode()) #输出我接收的信息
client.close() #关闭这个链接
然后在写一个服务器端
我们这里的服务器端是可以接收多个链接的,当第一个链接没有断开时,后面的链接一直等待,知道第一个链接终止,才会链接第二个..链接,依此类推。
并且完美解决了error:10054的强制关闭服务器端的错误!
import socket
# 建立一个服务端
server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
server.bind(('localhost',6969)) #绑定要监听的端口
server.listen(5) #开始监听 表示可以使用五个链接排队
while True:
# conn就是客户端链接过来而在服务端为期生成的一个链接实例
conn,addr = server.accept() #等待链接,多个链接的时候就会出现问题,其实返回了两个值
print(conn,addr)
while True:
try:
data = conn.recv(1024) #接收数据
print('recv:',data.decode()) #打印接收到的数据
conn.send(data.upper()) #然后再发送数据
except ConnectionResetError as e:
print('关闭了正在占线的链接!')
break
conn.close()
server.close() #然后关闭服务
测试方法,先运行服务器端脚本,
然后运行客户端脚本,并发送信息,
再次打开运行一个客户端脚本,并发送信息。
会发现,会在等待第一个链接断开,当第一个链接断开的时候就会开启第二个链接,这里已经解决了当起一个链接断开的时候强制关闭服务器端。
今天的文章Python网络编程Socket应用,并解决了error:10054错误分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/12765.html