发布时间:2019-09-09 08:43:12编辑:auto阅读(2346)
如果通过抓包工具抓到一个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 打印语句
51108
50500
41115
37963
32430
29331
28203
23047
23013
21337
1372°
2071°
1723°
1652°
1941°
1726°
2396°
4049°
3933°
2804°