问题描述
嗨,我希望用户只能看到自己创建的内容。在烧瓶中,我创建了一个用户表和所有其他表作为对该表的引用。所以当视图被调用时,我会过滤当前用户,只显示用户的条目。我现在检查了flask app builder,它有一些不错的用户管理,但它似乎没有我需要的东西。
我的解决方案是:创建一个从我的表到用户表的引用,并像我用普通烧瓶那样做。我只是想知道是否有更好的方法来做到这一点,也许 appbuilder 中已经有一些我必须激活但还没有看到的东西。
我的烧瓶解决方案:
user_id = db.Column(db.Integer,db.ForeignKey('user.id'))
这就是我在路由中查询它的方式
articles_pos = ArticlePos.query.filter_by(user_id=current_user.id)
提前致谢
解决方法
可以在 fab 本身的示例中找到解决方案。见https://github.com/dpgaspar/Flask-AppBuilder/tree/master/examples/extendsecurity
在我的特殊情况下,我做了以下更改
在模型中我添加了以下内容:
class MyUser(User):
__tablename__ = "ab_user"
在我引用用户表的类中
user = relationship("MyUser")
user_id = Column(Integer,ForeignKey('ab_user.id'),default=get_user_id,nullable=False)
你仍然需要这个函数:
@classmethod
def get_user_id(cls):
try:
return g.user.id
except Exception:
return None