如何还原 HTTP 请求日志中的 URL 编码参数?详解 %40 到 @

在记录HTTP请求的日志中出现了这样的情况:

python 复制代码
2024-11-20 11:12:49 INFO network_request gz_login 96  Body: countryAbbr=CN&countryCode=86&email=1222405567%40qq.com&password=12354e50456db124f9f34e2789308733&type=1

出现这种情况的原因是:%40 是 URL 编码后的 @ 符号,说明请求体中的参数被编码后记录下来了。这是因为在 HTTP 请求中,某些特殊字符(如 @, &, =)会被 URL 编码以确保安全性。但是看着不直观,如果有其他特殊符号可能就不知道是什么意思了。

解决这个问题可以使用Python 的 urllib.parse.unquote 函数,将 URL 编码的内容解码为原始格式

python 复制代码
import logging
from urllib.parse import unquote

logger = logging.getLogger(__name__)

def gz_login(pm):
    # 发送请求
    rsp = requests.post(url, headers=HEADERS, data=data, timeout=(10, 10), verify=False)
    rsp.raise_for_status()

    # 日志记录前对请求体解码
    decoded_body = unquote(rsp.request.body.decode('utf-8') if isinstance(rsp.request.body, bytes) else rsp.request.body)

    logger.info("==== HTTP Request ====")
    logger.info(f"Body (decoded): {decoded_body}")

rsp.request.body

rsp 是 requests 模块的响应对象。

rsp.request 表示与该响应关联的请求对象。

rsp.request.body 是请求体的内容,可能是二进制字节(bytes)格式或字符串(str)格式。

if isinstance(rsp.request.body, bytes)

检查 rsp.request.body 是否为字节类型。

如果是字节类型,则需要先解码为字符串。

rsp.request.body.decode('utf-8')

对字节类型的 body 使用 UTF-8 编码进行解码,得到一个字符串。

else rsp.request.body

如果 body 已经是字符串类型,直接使用它。

unquote(...)

对字符串中的 URL 编码字符进行解码。

例如,%40 会被解码为 @,%20 会被解码为空格。

即,如果 rsp.request.body 是字节类型,先解码为字符串;如果是字符串,直接使用。

然后对该字符串进行 URL 解码,得到原始的请求体内容。

这样做的好处是:

1、提高可读性

URL 编码后数据包含 %XX 格式的转义字符,解码后更直观易读。

2、调试方便

在记录日志或调试时,可以直接打印出解码后的请求体内容。

相关推荐
码界筑梦坊12 分钟前
99-基于Python的京东手机数据分析及预测系统
python·智能手机·数据分析·django·毕业设计·scikit-learn
肩塔didi24 分钟前
用 Pixi 管理 Python 项目:打通Conda 和 PyPI 的边界
后端·python·github
秋难降27 分钟前
正则表达式:为什么它成了程序员的 “分水岭”?
python·算法·正则表达式
CONGOREDE44 分钟前
DAY 37 早停策略和模型权重的保存
python·神经网络
在钱塘江1 小时前
LangGraph构建Ai智能体-7-智能体人机交互-HITL
人工智能·python
跟橙姐学代码1 小时前
学 Python 就像谈恋爱:从暧昧试探到正式牵手,我用 8 个瞬间讲透了!
python
2501_916013741 小时前
移动端网页调试实战,跨设备兼容与触控交互问题排查全流程
android·ios·小程序·https·uni-app·iphone·webview
令狐寻欢1 小时前
AI 大模型应用进阶系列(五):FastAPI 入门
人工智能·python·fastapi
传奇开心果编程2 小时前
【传奇开心果系列】Flet框架平面级联菜单侧边栏和和登录用户圆形头像自定义组件模板
python·ui·前端框架
Gu_shiwww2 小时前
数据结构2线性表——顺序表
c语言·开发语言·数据结构·python