要捕获一个具有乱码主体的HTTP POST请求,您可以使用以下代码示例:
import urllib.parse
from http.server import BaseHTTPRequestHandler, HTTPServer
class RequestHandler(BaseHTTPRequestHandler):
def do_POST(self):
content_length = int(self.headers['Content-Length'])
post_data = self.rfile.read(content_length)
# 解码乱码主体
decoded_data = post_data.decode('utf-8', 'replace')
# 打印解码后的数据
print(decoded_data)
self.send_response(200)
self.send_header('Content-type', 'text/plain')
self.end_headers()
self.wfile.write(b'Success')
def run(server_class=HTTPServer, handler_class=RequestHandler, port=8000):
server_address = ('', port)
httpd = server_class(server_address, handler_class)
print('Server running at localhost:{}'.format(port))
httpd.serve_forever()
if __name__ == '__main__':
run()
使用上述代码,您可以创建一个简单的HTTP服务器来接收POST请求并打印乱码主体的内容。代码中的do_POST
方法会解析请求头中的Content-Length,并使用self.rfile.read
方法读取请求主体数据。然后,使用decode
方法将乱码主体解码为utf-8编码的字符串,其中'replace'参数表示在解码过程中遇到无法解析的字符时将其替换为特殊字符。最后,您可以将解码后的数据用于任何进一步处理。
请注意,在实际应用中,您可能需要根据请求中的Content-Type首部来确定正确的解码方式,而不是简单地使用utf-8编码。
上一篇:捕获一个JSON响应