首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Flask-主体要求在调用Flask-登录request_loader之前触发异常

Flask-主体要求在调用Flask-登录request_loader之前触发异常
EN

Stack Overflow用户
提问于 2018-05-06 01:06:53
回答 1查看 133关注 0票数 2

一段时间以来,我一直使用Flask-Login处理传统的用户名/密码身份验证请求,使用Flask-Principal处理针对后续请求的路由的授权检查。一切都很好。

我现在正在尝试利用Flask-Login的"request_loader“装饰器在命中受保护端点的同一请求中处理基于头的身份验证。

我遇到的问题是,Flask-Principal的"require“装饰器似乎是在Flask-Login的"request_loader”之前执行的。在下面的示例中,在代码尝试对用户进行身份验证之前,我遇到了一个403未经授权的HTTP异常触发。

我肯定错过了一些愚蠢的东西,因为基于头的身份验证的要点--我相信--是在任何端点授权检查之前执行它……

烧瓶-登录使用:

代码语言:javascript
运行
复制
login_manager = LoginManager(app)
login_manager.anonymous_user = User
login_manager.session_protection = 'strong'
@login_manager.request_loader
def load_user_from_request(request):
    # do stuff, return User if found

烧瓶-主要用途:

代码语言:javascript
运行
复制
@blueprint.route('/some/endpoint', methods=['GET'])   
@read_permission.require(http_exception=403)
def some_function():
    # Do stuff

编辑:

顺便说一句,Flask的"before_request“函数似乎比其他函数更早被调用,所以从理论上讲,我可以从那里处理基于头的身份验证,但不使用为此目的而设计的Flask-Login函数似乎很脏……

EN

回答 1

Stack Overflow用户

发布于 2018-05-06 20:12:33

我最终将身份验证逻辑移到了@app.before_request函数中,这确实起作用了,所以我将此标记为答案,直到出现更好的结果。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50192011

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档