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
您好,我希望用户只能看到自己创建的内容。在 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