基于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对象,如果不关闭,还可以继续接收

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

 

 

 

posted @ 2019-07-31 15:32  Bonnie宝仪  阅读(292)  评论(0编辑  收藏  举报