socket

在这里插入图片描述

  • sk.bind(address)
      s.bind(address) 将套接字绑定到地址。address地址的格式取决于地址族。在AF_INET下,以元组(host,port)的形式表示地址。

  • sk.listen(backlog)
      开始监听传入连接。backlog指定在拒绝连接之前,可以挂起的最大连接数量。backlog等于5,表示内核已经接到了连接请求,但服务器还没有调用accept进行处理的连接个数最大为5。这个值不能无限大,因为要在内核中维护连接队列

  • sk.accept()
      接受连接并返回(conn,address),其中conn是新的套接字对象,可以用来接收和发送数据。address是连接客户端的地址。接收TCP 客户的连接(阻塞式)等待连接的到来

服务器端程序
#导入模块
import socket
#创建实例
sk = socket.socket()
#定义绑定ip和port
ip_port =("127.0.0.1",8888)
#绑定监听
sk.bind(ip_port)
#最大连接数
sk.listen(5)
# 提示信息
print("正在进行等待接收数据...")
#接收数据
conn,address = sk.accept()
#定义信息
msg="hello world"
#返回信息
conn.send(msg.encode())
#主动关闭连接
conn.close
  • client.connect(address)
      连接到address处的套接字。一般,address的格式为元组(hostname,port),如果连接出错,返回socket.error错误。
  • client.send(string[,flag])
      将string中的数据发送到连接的套接字。返回值是要发送的字节数量,该数量可能小于string的字节大小。即:可能未将指定内容全部发送。
  • client.recv(bufsize[,flag])
      接受套接字的数据。数据以字符串形式返回,bufsize指定最多可以接收的数量。flag提供有关消息的其他信息,通常可以忽略。
客户端程序
#导入模块
import socket

#实例初始化
client= socket.socket()
#访问服务器端的IP端口
ip_port =("127.0.0.1",8888)
#连接主机
client.connect(ip_port)
#接收主机信息
data = client.recv(1024)
#打印接收的数据
print(data.decode())

连续消息发送

-服务器端程序

#导入模块
import socket
import random
#创建实例
sk = socket.socket()
#定义绑定ip和port
ip_port =("127.0.0.1",8888)
#绑定监听
sk.bind(ip_port)
#最大连接数
sk.listen(5)
#不断循环,不断接收数据
while True:
    # 提示信息
    print("正在进行等待接收数据...")
    #接收数据
    conn,address = sk.accept()
    #定义信息
    msg="连接成功"
    #返回信息
    conn.send(msg.encode())
    #不断接收客服端发来的消息
    while True:
        #接收客户端消息
        data = conn.recv(1024)
        #打印数据
        print(data.decode())
        #接收到退出指令
        if data ==b'exit':
            break
        #处理客户端数据
        conn.send(data)
        #发送随机数信息
        conn.send(str(random.randint(1,1000)).encode())
    #主动关闭连接
    conn.close

  • 客户端程序
#导入模块
import socket

#实例初始化
client= socket.socket()
#访问服务器端的IP端口
ip_port =("127.0.0.1",8888)
#连接主机
client.connect(ip_port)
while True:
    # 接收主机信息
    data = client.recv(1024)
    # 打印接收的数据
    print(data.decode())
    # 定义一个循环,不断地发送消息
    #输入发送的消息
    msg_input=input("请输入发送的消息:")
    #消息发送
    client.send(msg_input.encode())
    if msg_input=="exit":
        break
    data= client.recv(1024)
    print(data.decode())

UDP和TCP有什么区别

1、连接方面区别

TCP面向连接(如打电话要先拨号建立连接)。

UDP是无连接的,即发送数据之前不需要建立连接。

2、安全方面的区别

TCP提供可靠的服务,通过TCP连接传送的数据,无差错,不丢失,不重复,且按序到达。

UDP尽最大努力交付,即不保证可靠交付。
3、传输效率的区别

TCP传输效率相对较低。

UDP传输效率高,适用于对高速传输和实时性有较高的通信或广播通信。

4、连接对象数量的区别

TCP连接只能是点到点、一对一的。

UDP支持一对一,一对多,多对一和多对多的交互通信。

udp

  • 服务器端程序
#导入模块
import socket

#创建实例
sk = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
#定义绑定的ip和port
ip_port=("127.0.0.1",8888)
#绑定监听
sk.bind(ip_port)
#不断循环接受数据
while True:
    #接收数据
    data= sk.recv(1024)
    #打印数据
    print(data.decode())
  • 客户端程序
#导入模块
import socket

#定义实例
sk=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
#定义需要连接的服务器的ip和port
ip_port=("127.0.0.1",8888)
#循环数据的输入
while True:
    #输入发送的信息
    msg_input = input("请输入发送的消息:")
    #退出循环条件
    if msg_input =="exit":
        break
    #数据发送
    sk.sendto(msg_input.encode(),ip_port)
#发送关闭信息
sk.close()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值