2

Flask-Mongoengine と Flask-Login を使用してアプリの承認をコーディングしようとしています。そして、私はこの奇妙なエラーを受け取ります:

File "/usr/lib/python3.5/site-packages/mongoengine/base/document.py", line 188, in __setattr__
    super(BaseDocument, self).__setattr__(name, value)
  File "/usr/lib/python3.5/site-packages/mongoengine/base/fields.py", line 132, in __set__
    if instance._initialised:
AttributeError: _initialised

私のmodels.py:

from app import app, db
from flask.ext.login import LoginManager


login_manager = LoginManager()
login_manager.init_app(app)


class User(db.Document):
    email = db.StringField(required=True)
    first_name = db.StringField(max_lenght=40, required=True)
    last_name = db.StringField(max_lenght=40, required=True)
    password = db.StringField(required=True)

    def __init__(self, email, first_name, last_name, password):
        self.email = email
        self.first_name = first_name
        self.last_name = last_name
        self.password = password

    def is_authenticated(self):
        return True

    def is_active(self):
        return True

    def is_anonymous(self):
        return False

   def get_id(self):
        return self.email

クラスを超越しようとしましたが、役に立ちませんでした。

https://github.com/MongoEngine/flask-mongoengine/issues/156

4

4 に答える 4

5

Mongoengine では __init__ を定義する必要はありません。

class User(db.Document):
    email = db.StringField(required=True)
    first_name = db.StringField(max_lenght=40, required=True)
    last_name = db.StringField(max_lenght=40, required=True)
    password = db.StringField(required=True)

    def clean(self):
        # clean will be called when you call .save()
        # You can do whatever you'd like to clean data before save
        self.password = str(self.password)

その後、あなたがしなければならないのは

user = User(email='email@gmail', first_name='hello', last_name='there', password=2342143213)
user.save()
print(user.id)
于 2016-10-28T22:12:31.877 に答える
0

将来の読者は、ニットルダンの回答よりも注意する必要があります。これは、すべてclean()の呼び出しの前に呼び出されるため、モデルのパスワード フィールドをハッシュするために使用される場合は、次のようになります。 save()

def clean(self):
    self.password = bcrypt.generate_password_hash(self.password).decode('utf-8')

パスワードは常に上書きされますが、これは望ましくありません。回避策は、次のような追加のフィールドを使用することです。password_hashed = db.BooleanField(default=False)

def clean(self):
    if not self.password_hashed:
        self.password        = bcrypt.generate_password_hash(self.password).decode('utf-8')
        self.password_hashed = True
于 2018-03-20T07:53:52.047 に答える