当前位置: 代码迷 >> 综合 >> 10.flask 信号
  详细解决方案

10.flask 信号

热度:52   发布时间:2023-09-12 07:09:20.0

安装

pip install blinker

自定义信号

自定义信号分三步,

  • 第一是定义一个信号
  • 第二是监听一个信号
  • 第三是发送一个信号
  1. 定义信号:定义信号需要使用到blinker这个包的Namespace类来创建一个命名空间。比如定义一个在访问了某个视图函数的时候的信号。示例代码如下:
from blinker import Namespace# Namespace的作用:为了防止多人开发的时候,信号名字冲突的问题mysignal = Namespace()
visit_signal = mysignal.signal('visit-signal')
  1. 监听信号:监听信号使用singel对象的connect方法,在这个方法中需要传递一个函数,用来接收以后监听到这个信号该做的事情。示例代码如下:
def visit_func(sender,username):print(sender,username)
  1. 发送信号:发送信号使用singal对象的send方法,这个方法可以传递一些其他参数过去。示例代码如下:
mysignal.send(username='angle')

signal_demo.py

from flask import Flask,request,render_template
from blinker import Namespace
from signals import login_signal# # Namespace 命名空间
# # 1.定义信号
# namespace = Namespace()
# fire_signal = namespace.signal('fire')
#
# # 2.监听信号
# def fire_test(sender):
#     print(sender)
#     print("start fire")
# fire_signal.connect(fire_test)
#
# # 3. 发送一个信号
# fire_signal.send()# 定义一个登陆的信号,以后用户登录进来以后就发送一个登陆信号,然后能够监听这个信号,然后能够监听这个信号,在监听到这个信号以后,就记录当前这个用户登录的信息,用信号的方式,记录用户的登录信息app = Flask(__name__)@app.route('/')
def hello_world():return 'Hello World!'@app.route('/login/')
def login():username = request.args.get('username')if username:login_signal.send(username=username)return '登录成功'else:return '请输入用户名'if __name__ == '__main__':app.run(debug=True)

signals.py

from blinker import Namespace
from datetime import datetime
from flask import requestnamespace = Namespace()login_signal = namespace.signal('login')# 监听
def login_log(sender,username):# print('用户登录')# 记录 用户名,登录时间,ip地址username = usernamenow = datetime.now()ip = request.remote_addrlog = "登录日志:用户名:{},登录时间:{},ip地址:{}\n".format(username,now,ip)print(log)with open('login_log.txt','a+',encoding='utf-8') as f:f.write(log)login_signal.connect(login_log)

Flask内置的信号讲解

  • template_rendered:模板渲染完毕后的信号
def template_rendered_func(sender,template,context):print("sender:{}".format(sender))print("template:{}".format(template))print("context:{}".format(context))
template_rendered.connect(template_rendered_func)
  • request_started:模板开始渲染
  • request_finished:模板完成渲染
  • request_tearing_down:request对象被销毁的信号
  • got_request_exception:视图函数发生异常的信号,一般可以监听这个信号,来记录网站异常信号
def request_exception_log(sender,exception):print(exception)
got_request_exception.connect(request_exception_log)
  • appcontext_tearing_down:app上下文被销毁的信号
  • appcontext_pushed:app上下文被推入到栈上的信号
  • appcontext_poped:app上下文被退出栈中的信号
  • message_flashed:调用了Flask的‘flashed’方法的信号