发布时间:2019-09-09 08:43:12编辑:auto阅读(2361)
如果通过抓包工具抓到一个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 打印语句
51214
50632
41252
38065
32530
29435
28299
23156
23116
21455
1506°
2225°
1847°
1787°
2083°
1841°
2514°
4228°
4091°
2923°