标签:内置模块 false pytho 初始化 异常 判断 bytes 调用 winerror
服务端套接字函数
s.bind() 绑定(主机,端口号)到套接字
s.listen() 开始TCP监听
s.accept() 被动接受TCP客户的连接,(阻塞式)等待连接的到来
客户端套接字函数
s.connect() 主动初始化TCP服务器连接
s.connect_ex() connect()函数的扩展版本,出错时返回出错码,而不是抛出异常
公共用途的套接字函数
s.recv() 接收TCP数据
s.send() 发送TCP数据
s.sendall() 发送TCP数据
s.recvfrom() 接收UDP数据
s.sendto() 发送UDP数据
s.getpeername() 连接到当前套接字的远端的地址
s.getsockname() 当前套接字的地址
s.getsockopt() 返回指定套接字的参数
s.setsockopt() 设置指定套接字的参数
s.close() 关闭套接字
面向锁的套接字方法
s.setblocking() 设置套接字的阻塞与非阻塞模式
s.settimeout() 设置阻塞套接字操作的超时时间
s.gettimeout() 得到阻塞套接字操作的超时时间
面向文件的套接字的函数
s.fileno() 套接字的文件描述符
s.makefile() 创建一个与该套接字相关的文件
连接时的套接字方法
s.settimeout(4) 设置等待超时时间,运行到accept时不会瞬间报错,而是会等待4秒等待客户端连接
s.gettimeout() 查询等待了用户多长时间连接
s.setblocking(False) 设置accept和recv两个方法的阻塞和非阻塞状态
#settimeout的用法,在一定时间内判断客户端是否超时 import socket sk = socket.socket() sk.bind((‘127.0.0.1‘,8090)) sk.listen() sk.settimeout(4)#四秒后没有客户端连接,报错超时 #如果我不运行上面的代码,程序会一直停留在这等待客户连接 coon,addr = sk.accept() print(sk.gettimeout())#得到上面settimeout设置的值 sk.settimeout(4) mes = coon.recv(1024) print(mes) coon.close() sk.close()
sock.sendall(‘Hello world\n‘) #这两段代码等价,sendall内部就是调用的send buffer = ‘Hello world\n‘ while buffer: bytes = sock.send(buffer) buffer = buffer[bytes:]
1)在这里先介绍一个点
解决方案:
import socket from socket import SOL_SOCKET,SO_REUSEADDR sk = socket.socket() sk.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) #在bind前面加这句话 sk.bind((‘127.0.0.1‘,8090))
2)socketserver模块为内置模块
标签:内置模块 false pytho 初始化 异常 判断 bytes 调用 winerror
原文地址:https://www.cnblogs.com/0627zhou/p/9501130.html