python中http.server关闭库打印的方法

本文介绍如何在Python的http.server模块中自定义CGIHTTPRequestHandler,以消除接收到HTTP请求时的默认日志打印。通过重写log_message方法并使其为空实现这一目标。示例代码展示了如何创建一个不打印日志的简单HTTP服务器。
Python3.10

Python3.10

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

如果没有实现log_message接口,接收到http请求时,库会自动有如下打印:

192.168.200.238 - - [15/Jun/2022 16:53:20] "GET /favicon.ico HTTP/1.1" 200 -

必须实现类http.server.CGIHTTPRequestHandler的方法log_message,并直接返回才行。代码如下:

import http.server
import socketserver

HOSTADDR = ""         #服务器IP
HOSTPORT = 8080       #服务器端口

class MyServer(http.server.CGIHTTPRequestHandler):

    def do_GET(self):        
        return

    #实现接口,去掉内置打印
    def log_message(self, format: str, *args):
        return

    def do_POST(self):
        return

def main():
    
    with socketserver.TCPServer((HOSTADDR, HOSTPORT), MyServer) as server:
        server.serve_forever()

if __name__ == '__main__':
    main()

在百度上搜索去掉python的http.server.CGIHTTPRequestHandler的打印,是搜索不到的,只有去谷歌上才能找到答案,算是填补空白了。

您可能感兴趣的与本文相关的镜像

Python3.10

Python3.10

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

Python中,`rsocket.recv`是用于从套接字接收数据的方法,通常在网络编程中使用。以下是关于它的使用方法、功能及相关注意事项的详细说明。 ### 功能 `rsocket.recv`方法的主要功能是从套接字接收数据。它会尝试从套接字的接收缓冲区中读取指定数量的字节数据。如果缓冲区中有数据,它会返回读取到的数据;如果缓冲区为空,它会阻塞程序,直到有数据到达或者发生超时(如果设置了超时时间)。 ### 使用方法 `rsocket.recv`方法的基本语法如下: ```python data = rsocket.recv(bufsize) ``` 其中,`rsocket`是一个已连接的套接字对象,`bufsize`是一个整数,表示要接收的最大字节数。返回值`data`是一个字节对象,包含从套接字接收到的数据。 以下是一个简单的示例代码,展示了如何使用`rsocket.recv`方法: ```python import socket # 创建一个TCP套接字 rsocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 连接到服务器 server_address = ('localhost', 8888) rsocket.connect(server_address) # 接收数据 bufsize = 1024 data = rsocket.recv(bufsize) # 打印接收到的数据 print(f"Received: {data.decode('utf-8')}") # 关闭套接字 rsocket.close() ``` ### 相关注意事项 1. **阻塞行为**:默认情况下,`rsocket.recv`是阻塞的。这意味着如果套接字的接收缓冲区为空,程序会暂停执行,直到有数据到达。如果不希望程序阻塞,可以使用`rsocket.setblocking(0)`方法将套接字设置为非阻塞模式。 ```python rsocket.setblocking(0) try: data = rsocket.recv(bufsize) except socket.error as e: print(f"Error: {e}") ``` 2. **缓冲区大小**:`bufsize`参数指定了要接收的最大字节数。如果实际接收到的数据少于`bufsize`,`recv`方法会立即返回。因此,可能需要多次调用`recv`方法才能接收完整的数据。 3. **数据解码**:`rsocket.recv`返回的是字节对象。如果需要将其转换为字符串,需要使用`decode`方法进行解码。 ```python data = rsocket.recv(bufsize) str_data = data.decode('utf-8') ``` 4. **超时设置**:可以使用`rsocket.settimeout(timeout)`方法设置`recv`方法的超时时间。如果在指定的时间内没有数据到达,会抛出`socket.timeout`异常。 ```python rsocket.settimeout(5) # 设置超时时间为5秒 try: data = rsocket.recv(bufsize) except socket.timeout: print("Timeout occurred.") ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值