python socket server_Python socket与socketserver

socket的更多方法

服务端套接字函数

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() 创建一个与该套接字相关的文件send和sendall方法

官方文档对socket模块下的socket.send()和socket.sendall()解释如下:socket.send(string[, flags])

Send data to the socket. The socket must be connected to a remote socket. The optional flags argument has the same meaning as for recv() above. Returns the number of bytes sent. Applications are responsible for checking that all data has been sent; if only some of the data was transmitted, the application needs to attempt delivery of the remaining data.

send()的返回值是发送的字节数量,这个数量值可能小于要发送的string的字节数,也就是说可能无法发送string中所有的数据。如果有错误则会抛出异常。

socket.sendall(string[, flags])

Send data to the socket. The socket must be connected to a remote socket. The optional flags argument has the same meaning as for recv() above.

Unlike send(), this method continues to send data from string until either all data has been sent or an error occurs. None is returned on success.

On error, an exception is raised, and there is no way to determine how much data, if any, was successfully sent.

尝试发送string的所有数据,成功则返回None,失败则抛出异常。

故,下面两段代码是等价的:

#sock.sendall('Hello world\n')

#buffer = 'Hello world\n'

#while buffer:

# bytes = sock.send(buffer)

# buffer = buffer[bytes:]

socketserver

server端

import socketserver

class Myserver(socketserver.BaseRequestHandler):

def handle(self):

self.data = self.request.recv(1024).strip()

print("{} wrote:".format(self.client_address[0]))

print(self.data)

self.request.sendall(self.data.upper())

if __name__ == "__main__":

HOST, PORT = "127.0.0.1", 9999

# 设置allow_reuse_address允许服务器重用地址

socketserver.TCPServer.allow_reuse_address = True

# 创建一个server, 将服务地址绑定到127.0.0.1:9999

server = socketserver.TCPServer((HOST, PORT),Myserver)

# 让server永远运行下去,除非强制停止程序

server.serve_forever()

client端

import socket

HOST, PORT = "127.0.0.1", 9999

data = "hello"

# 创建一个socket链接,SOCK_STREAM代表使用TCP协议

with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as sock:

sock.connect((HOST, PORT)) # 链接到客户端

sock.sendall(bytes(data + "\n", "utf-8")) # 向服务端发送数据

received = str(sock.recv(1024), "utf-8")# 从服务端接收数据

print("Sent: {}".format(data))

print("Received: {}".format(received))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值