gpt4 book ai didi

python - Flask-Admin 模型 View 配置

转载 作者:行者123 更新时间:2023-11-28 21:53:34 24 4
gpt4 key购买 nike

我正在尝试调整 Flask-Admin 模型 View 以仅在“编辑”和“创建”选项卡中显示某些列。到目前为止,我已经能够通过将其放入我的子类中来正确配置列表:

class AuthUserView(AuthModelView):
column_list = ('username', 'email', 'roles', 'last_login_at', 'login_count')

效果很好!但现在我的问题是这样的。还有一个附加到用户的密码字段。当编辑选项卡打开时,我希望该列不在编辑字段中。此外,当我创建一个用户时,我希望密码字段在那里,但在将输入存储到数据库之前对其进行加密(这意味着我只需要在“提交”和实际存储之间拦截数据。

是否可以进行这些自定义?感谢您的帮助!

编辑:所以我可以通过将此代码添加到我的 View 中来删除密码字段:

form_excluded_columns = ('password')

除了现在这会将它从编辑和创建表单中删除。不过,我只想将它从一个中删除。

最佳答案

成功了!图如果有人遇到这个问题,我会把我的答案放在这里...这是我最终的 AuthUserView 的样子

class AuthUserView(AuthModelView):
form_edit_rules = ('roles', 'active', 'username', 'email', 'confirmed_at', 'last_login_at', 'current_login_at', 'last_login_ip', 'current_login_ip', 'login_count')
column_list = ('username', 'email', 'roles', 'last_login_at', 'login_count')

def create_model(self, form):
form.password.data = encrypt_password(form.password.data)
super(AuthUserView, self).create_model(form)

我使用 form_edit_rules 从编辑字段中删除密码 key 。然后我覆盖 create_model 来加密密码,然后调用 super 方法来实际创建模型。

关于python - Flask-Admin 模型 View 配置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25898397/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com