发布时间:2019-09-09 08:43:12编辑:auto阅读(2418)
如果通过抓包工具抓到一个raw http request,想要解析它,可以使用如下方法。
编写一个继承自python内置基类BaseHTTPRequestHandler的类,代码如下:
from BaseHTTPServer import BaseHTTPRequestHandler
from StringIO import StringIO
class HTTPRequest(BaseHTTPRequestHandler):
def __init__(self, request_text):
self.rfile = StringIO(request_text)
self.raw_requestline = self.rfile.readline()
self.error_code = self.error_message = None
self.parse_request()
def send_error(self, code, message):
self.error_code = code
self.error_message = message# Using this new class is really easy!
request = HTTPRequest(request_text)
print request.error_code # None (check this first)
print request.command # "GET"
print request.path # "/who/ken/trust.html"
print request.request_version # "HTTP/1.1"
print len(request.headers) # 3
print request.headers.keys() # ['accept-charset', 'host', 'accept']
print request.headers['host'] # "cm.bell-labs.com"BaseHTTPServer.BaseHTTPRequestHandler”的说明。
欢迎扫描下方二维码关注我的微信公众号致新(zhixin991),那里有我的读书笔记,计算机科普和杂谈

上一篇: python 并发 ThreadPool
下一篇: Python 打印语句
51598
51192
41693
38453
32941
29929
28630
23595
23526
21875
2035°
2745°
2291°
2225°
2703°
2247°
3000°
4936°
4794°
3412°