基于tcp协议的socket

#serve服务端
import socket
sk=socket.socket()#实例对象
sk.bind(('127.0.0.1',8080))#集合内设置IP和端口,利用bind方法
sk.listen()#监听信息
conn,addr=sk.accept()#接受到信息
while True:
ret = conn.recv(1024).decode('utf-8')#收到信息并解码,设置接收直接大小为1024,1024的整数倍都可以
print(ret)
if ret=='bye':
conn.send(bytes('再见',encoding='utf-8'))#发送信息,信息必须为bytes类型
break
ret = input('>>>')
conn.send(bytes(ret,encoding='utf-8'))
conn.close()
sk.close()

 

#client客户端
import socket
sk=socket.socket()
sk.connect(('127.0.0.1',8080))##集合内设置IP和端口,利用connect方法
while True:
info=input('>>>')
sk.send(bytes(info,encoding='utf-8'))#编码发送bytes类型信息
ret=sk.recv(1024).decode('utf-8')#解密
print(ret)
sk.close()

 

多个程序与服务器连接

#serve服务端
import socket
sk=socket.socket()#买手机,创建一个socket实例对象
sk.bind(('127.0.0.1',8080))#集合内设置IP和端口,服务器利用bind方法
sk.listen()#监听信息
while True:
conn,addr = sk.accept() # 获取一个客户端的连接,已经完成三次握手的一个连接
#如果未建立连接,一直等待,及阻塞
while 1:
ret = conn.recv(1024).decode('utf-8')#收到信息并解码,设置接收直接大小为1024,1024的整数倍都可以
print(ret)
if ret=='bye':
conn.send(bytes('再见',encoding='utf-8'))#发送信息,信息必须为bytes类型
break
ret = input('>>>')
conn.send(bytes(ret,encoding='utf-8'))
conn.close() #关闭连接
sk.close() #关闭socket对象,如果不关闭,还可以继续接收

注意:当客户端与服务端连接上时,另一个客户端想连接服务端时,只能等前一个客户端和服务端断开连接时,才能连接上

 
 

 

转载于:https://www.cnblogs.com/account/p/11276647.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值