色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Python Http請求json解析庫用法解析

瀏覽:5日期:2022-07-04 08:04:12

httpparser介紹

:1.解析字節類型的http與https請求數據

:2.支持已k-v形式修改請求數據

:3.支持重新編碼請求數據

源碼

import json__author = '-ling'def parser(request_data): # 獲取請求的三個段: # 1.請求方法 URI協議 版本 # 2.請求頭(Request Header) # 3.請求正文 index0 = request_data.find(b'rnrn') request_predata = request_data[0:index0] index1 = request_predata.find(b'rn') # 請求方法 URI協議 版本 request_first_data = request_predata[0:index1].decode('utf-8') request_first = {} count = 0 list = ['method', ’url’, ’version’] for line in request_first_data.split(' '): if line != '': request_first[list[count]] = line count += 1 # print('解析請求方法 URI協議 版本:',request_first) # 請求頭(Request Header) request_header_data = request_predata[index1:].decode('utf-8') request_headers = {} for line in request_header_data.split('rn'): if line != '': line = line.replace(' ','') restemp = line.split(':') if restemp[0] == 'Host' and len(restemp) == 3:restemp[1] = restemp[1] + ':' +restemp[2] request_headers[restemp[0]] = restemp[1] # print('請求頭(Request Header):',request_headers) # 請求正文 request_nextdata = request_data[index0:].decode('utf-8') request_content_temp = request_nextdata.replace('rn', '') request_content = None if request_content_temp != '': try: request_content = json.loads(request_content_temp) except: request_content = {’content’:request_content_temp} # print('請求正文:',request_content) else: pass # print('無請求正文!') return request_first,request_headers,request_content,request_nextdatadef update_first_data(request_first_data,field,data): request_first_data[field] = datadef update_request_headers(request_headers,field,data): request_headers[field] = datadef update_request_content(request_content,field,data): request_content[field] = datadef encode(request_first_data,request_headers,request_content): request_data = b'' list = ['method', ’url’, ’version’] for key in list: request_data += (request_first_data[key] + ' ').encode('utf-8') request_data += 'rn'.encode('utf-8') for key in request_headers.keys(): request_data += (key + ':' + request_headers[key]).encode('utf-8') request_data += 'rn'.encode('utf-8') request_data += 'rn'.encode('utf-8') if request_content != None: request_data += json.dumps(request_content).encode('utf-8') # print('重新編碼以后的數據:',request_data.decode('utf-8')) return request_data

如何使用

1.解析請求數據

request_first,request_headers,request_content,request_nextdata = httpparser.parser(request_data)

2.修改或者增加各個部分的字段使用

update_first_data :修改第一行字段數據 update_request_headers :修改請求頭或者增加請求頭字段 update_request_content :修改請求內容字段或者增加請求內容

3.再編碼三個部分的數據

encode(request_first_data,request_headers,request_content)

示例(http返回數據如下):

b’HTTP/1.0 200 OKrnContent-Type: text/html; charset=utf-8rnContent-Length: 13rnServer: Werkzeug/1.0.1 Python/3.7.7rnDate: Thu, 15 Oct 2020 02:58:54 GMTrnrn<h1>foo!</h1>’

解析出來的數據:

注意:(parser傳入字節類型數據)

解析數據: {’method’: ’HTTP/1.0’, ’url’: ’200’, ’version’: ’

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 青木玲中文字幕一区二区 | 国产精品情人露脸在线观看 | 欧美日韩亚洲高清不卡一区二区三区 | 午夜欧美| 欧美精品一区二区三区四区 | 美女张开腿让男人桶的 视频 | 中文字幕一区在线 | 国产99视频精品免视看9 | 免费男女乱淫真视频播放 | 日本免费在线 | 亚洲国产成a人v在线观看 | 中文字幕日本一区波多野不卡 | 国产高清一级片 | 找国产毛片 | 国产成人一区免费观看 | 97婷婷狠狠成人免费视频 | 97视频网站| 手机av在线播放 | 成人爽a毛片在线视频网站 成人爽爽大片在线观看 | 亚洲大片免费观看 | 午夜欧美精品久久久久久久久 | 怡红院免费播放全部视频 | 不卡一区在线观看 | 国产成人免费视频 | 亚洲欧洲一级 | 亚洲综合天堂网 | 国产成人午夜性a一级毛片 国产成人午夜性视频影院 国产成人香蕉久久久久 | 亚洲理论视频 | 成人中文字幕在线观看 | 日韩精品视频在线 | 黄频漫画 | 在线亚洲观看 | 午夜三级国产精品理论三级 | 免费国产精品视频 | 成人在线视频一区 | 色偷偷资源网 | 亚洲 [12p]| 美女被免费视频网站a国产 美女被免费网站视频软件 美女被免费网站在线软件 美女被免费网站在线视频软件 | 特级片在线观看 | 国产欧美日韩在线一区二区不卡 | 又粗又爽又色男女乱淫播放男女 |