日志中添加Referrer信息

在Flask中使用默认的logging模块进行日志记录时,可以通过在日志记录器中添加Referrer字段来包含请求的Referrer信息。您可以通过以下方式进行修改:

import logging
from logging.handlers import RotatingFileHandler
from flask import Flask, request

app = Flask(__name__)

# 创建日志记录器
logger = logging.getLogger('my_logger')
logger.setLevel(logging.INFO)

# 设置日志格式
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')


# 创建错误日志处理器
error_handler = RotatingFileHandler('logs/error.log', encoding='utf-8', maxBytes=10485760, backupCount=10)
error_handler.setLevel(logging.ERROR)
error_handler.setFormatter(formatter)
logger.addHandler(error_handler)

# 创建普通日志处理器
handler = RotatingFileHandler('logs/app.log', encoding='utf-8-sig', maxBytes=10485760, backupCount=10)
handler.setLevel(logging.INFO)
handler.setFormatter(formatter)
logger.addHandler(handler)


# 设置文件编码为 UTF-8
log_file = codecs.open('logs/app.log', mode='a', encoding='utf-8')
handler.stream = log_file



# 记录带有Referrer的日志
@app.after_request
def log_request(response):
referrer = request.referrer
app.logger.info('Referrer: %s', referrer)
return response
 


if __name__ == '__main__':
    app.run()
 

在上述代码中,通过request.referrer获取请求的Referrer信息,并将其添加到日志记录中。您可以在适当的位置使用logger.info('Referrer: %s', referrer)语句记录带有Referrer字段的日志。

请注意,要正确使用request.referrer,您需要确保请求中包含Referer(注意拼写)头部,并且该头部的值有效。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值