当前位置:   article > 正文

Flask 统一拦截器

Flask 统一拦截器
  1. import os
  2. from flask import Flask, request, session
  3. app = Flask(__name__)
  4. app.config['SECRET_KEY'] = os.urandom(24) # 生成24位的随机数种子,用于产生SESSION ID
  5. @app.route('/article/<int:article_id>')
  6. def test(article_id):
  7. """
  8. 路由地址参数, 必须同步定义在接口函数里,作为形参
  9. """
  10. return f'你正在访问编号为:{article_id}的文章'
  11. @app.route('/sess')
  12. def sess():
  13. session['is_login'] = 'true'
  14. return 'done'
  15. @app.before_request
  16. def before():
  17. """
  18. 针对app实例定义全局拦截器
  19. """
  20. url = request.path # 读取到当前接口的地址
  21. if url == '/sess':
  22. pass
  23. elif session.get('is_login', '') != 'true':
  24. return '你还没有登录'
  25. else:
  26. pass
  27. if '__name__' == '__main__':
  28. app.run()

模块拦截器

也叫视图拦截器,只针对某一个模块进行拦截,应用于Blueprint模块中。

把需要事前拦截的接口和拦截器一起放在一个视图模板里

 

comment = Blueprint('comment', __name__)

# #评论操作前通过模块拦截器判断--用户是否登录
@comment.before_request
def before_comment():
    #未登录情况下允许获取评论
    if session.get('islogin') is None or session.get('islogin') != 'true':
        # return '你还没有登录,不能发表评论'
        return 'not-login'
 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/570702
推荐阅读
相关标签
  

闽ICP备14008679号