从日志记录中删除特定于块的端点

2024-10-01 00:26:47 发布

您现在位置:Python中文网/ 问答频道 /正文

在我的flask应用程序中,我与bokeh进行了一些ajax调用,为了获取其数据,bokeh plot每秒对某个端点执行一次POST请求,现在我不断得到如下输出:

127.0.0.1 - - [25/May/2020 12:50:17] "POST /statusdata/ HTTP/1.1" 200 -
127.0.0.1 - - [25/May/2020 12:50:17] "POST /statusdata/ HTTP/1.1" 200 -
127.0.0.1 - - [25/May/2020 12:50:19] "POST /statusdata/ HTTP/1.1" 200 -
127.0.0.1 - - [25/May/2020 12:50:19] "POST /statusdata/ HTTP/1.1" 200 -

如何从flask的调试日志中排除route/statusdata/? 谢谢你的帮助


Tags: 数据应用程序httpflaskplotbokehajax端点
1条回答
网友
1楼 · 发布于 2024-10-01 00:26:47

您可以向记录器添加自定义筛选器以查找路由名称。如果您只是使用开发服务器,那么这将是werkzeug处理程序。当您转到生产时,您必须找到特定的处理程序。完整示例(您可以在浏览器控制台中监视该示例,以确认表单已提交,尽管服务器上没有显示任何记录):

from flask import Flask, render_template_string
import logging


class AjaxFilter(logging.Filter):
    def filter(self, record):  
        return "statusdata" not in record.getMessage()

log = logging.getLogger('werkzeug')
log.addFilter(AjaxFilter())


home_template = """
<form method="post" action="{{ url_for('route_a') }}" class="testAjax">
<input type="submit" value="submit A">
</form>

<form method="post" action="{{ url_for('statusdata') }}" class="testAjax">
<input type="submit" value="submit B">
</form>
<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
<script>
   $(".testAjax").submit(function(e) {
       e.preventDefault();
       var form = $(this);
       var url = form.attr('action');

       $.ajax({
           type: "POST",
           url: url,
           data: form.serialize(),
           context: form,
           success: function(resp) {
               console.log(resp);   
           }
       });
   });
</script>
"""

app = Flask('__name__')


@app.route('/')
def home():
    return render_template_string(home_template)

@app.route('/a', methods=['POST'])
def route_a():
    return "1"

@app.route('/statusdata/', methods=['POST'])
def statusdata():
    return "2"

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

相关问题 更多 >