接受UDP套接字的数据。与recv()类似,但返回值是(data,address)。其中data是包含接收数据的字符串,address是发送数据的套接字地址。
socket.sendto(string[,flag],address)
发送UDP数据。将数据发送到套接字,address是形式为(ipaddr,port)的元组,指定远程地址。返回值是发送的字节数。
socket.close()
关闭套接字。
socket.getpeername()
返回连接套接字的远程地址。返回值通常是元组(ipaddr,port)。
socket.getsockname()
返回套接字自己的地址。通常是一个元组(ipaddr,port)
socket.setsockopt(level,optname,value)
设置给定套接字选项的值。
socket.getsockopt(level,optname[.buflen])
返回套接字选项的值。
socket.settimeout(timeout)
设置套接字操作的超时期,timeout是一个浮点数,单位是秒。值为None表示没有超时期。一般,超时期应该在刚创建套接字时设置,因为它们可能用于连接的操作(如connect())
socket.fileno()
返回套接字的文件描述符。
socket.setblocking(flag)
如果flag为0,则将套接字设为非阻塞模式,否则将套接字设为阻塞模式(默认值)。非阻塞模式下,如果调用recv
socket.makefile()
创建一个与该套接字相关连的文件
三 创建socket连接
服务端
1 创建socket对象。
tcpSock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
2 使用bind方法来将socket绑定到指定地址和端口。
tcpSock.bind(address,port)
3 使用listen方法接收连接请求。
tcpSock.listen( backlog )
backlog指定最多允许多少个客户连接到服务器。它的值至少为1。收到连接请求后,这些请求需要排队,如果队列满,就拒绝请求。
4 通过socket的accept方法等待客户请求连接。
connection, address = socket.accept()
调用accept方法时,socket会时入"waiting"状态,等待客户请求连接,当客户端发送请求到服务端时,accept方法建立连接并返回服务器。accept方法返回一个含有两个元素的 元组(connection,address)。
第一个元素 connection是新的socket对象,服务器必须通过它与客户通信;
第二个元素 address是客户的IP地址。
5 处理阶段,服务器和客户端通过send和recv方法通信(传输数据)。服务器调用send方法以字符串形式向客户发送数据,也可以使用recv方法从客户接收信息。调用recv时,
服务器必须设置接收的最大数据量。recv方法在接收数据时会进入“blocked”状态,最后返回一个字符串,用它表示收到的数据。
如果发送的数据量超过recv所允许接收的限制,数据会被截断。多余的数据将缓冲于接收端。下一次调用recv时,多余的数据会从缓冲区删除(以及自上次调用recv以来,客户可能发送的其它任何数据)
6 传输结束,服务器调用socket的close方法关闭连接。
客户端
1 创建一个socket以连接服务器,和服务器端创建socket对象一样。
tcpCliSock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
2 使用socket的connect方法连接服务器。
tcpCliSock.connect( (host,port) )
host代表服务器主机名或IP,port代表服务器进程所绑定的端口号。如连接成功,客户就可通过套接字与服务器通信,如果连接失败,会引发socket.error异常。
3 处理阶段,客户和服务器将通过send方法和recv方法通信。
tcpCliSock.send(data)
4 传输结束,客户通过调用socket的close方法关闭连接。
tcpCliSock.close()
一图胜千言 ,socket 建立连接的过程 via