flask app builder 用户应该只能看到自己的内容

flask app builder user should see only own content

您好,我希望用户只能看到自己创建的内容。在 flask 中,我创建了一个用户 table 和所有其他 table 作为对 table 的引用。因此,当调用视图时,我会为当前用户过滤并仅显示用户的条目。我现在检查了 flask app builder,它有一些很好的用户管理,但它似乎没有我需要的东西。

我的解决方案是:创建一个从我的 table 到用户 table 的引用,并像我用普通烧瓶那样做。我只是想知道是否有更好的方法来做到这一点,也许 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"

在 class 中我引用了用户 table

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