栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在Flask中使用参数制作python装饰器函数(用于授权)

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在Flask中使用参数制作python装饰器函数(用于授权)

方法如下:

from functools import update_wrapperdef owns_hotdog(hotdog):    def decorator(fn):        def wrapped_function(*args, **kwargs): # First check if user is authenticated. if not logged_in():     return redirect(url_for('login')) # For authorization error it is better to return status pre 403 # and handle it in errorhandler separately, because the user could # be already authenticated, but lack the privileges. if not authorizeowner(hotdog):     abort(403) return fn(*args, **kwargs)        return update_wrapper(wrapped_function, fn)    return decorator@app.errorhandler(403)def forbidden_403(exception):    return 'No hotdogs for you!', 403

当装饰器接受参数时,它实际上不是装饰器,而是返回 真正 装饰器的 工厂 函数。 __

但是,如果我是您,我将使用Flask-Login进行身份验证,并使用自定义装饰器和功能将其扩展,以处理授权。

我查看了Flask-Principal,但发现我的口味过于复杂。还没有检查过Flask-Security,但是我相信它使用Flask-
Principal进行授权。总的来说,我认为大多数情况下,使用一些自定义代码的Flask-Login就足够了。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/660908.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号