Python Flask:AttributeError:“NoneType”对象没有属性“is\u active”

2024-05-15 02:44:06 发布

您现在位置:Python中文网/ 问答频道 /正文

我正试着用烧瓶学习。在part 5 of the tutorial中,我现在正在构建一个需要用户登录的配置文件页。

因为我使用的是peewee ORM而不是SQLAlchemy,所以我会在这里和那里调整代码,但对于这种情况,我认为这并不重要。我现在使用我的Google(openID)帐户登录,并遇到一个错误,说AttributeError: 'NoneType' object has no attribute 'is_active'。这个错误发生在这个函数的最后一行,上面写着login_user(user, remember = remember_me)

@oid.after_login
def after_login(resp):
    if resp.email is None or resp.email == "":
        flash('Invalid login. Please try again.')
        return redirect(url_for('login'))

    user = User.select().where(User.email == resp.email).first()

    if user is None:
        nickname = resp.nickname
        if nickname is None or nickname == "":
            nickname = resp.email.split('@')[0]
        User(nickname = nickname, email = resp.email, role = models.ROLE_USER, last_seen = datetime.utcnow()).save()

    remember_me = False
    if 'remember_me' in session:
        remember_me = session['remember_me']
        session.pop('remember_me', None)
    login_user(user, remember = remember_me)
    return redirect(request.args.get('next') or url_for('index'))

因为这段代码以前工作过,我不知道为什么现在会出现错误。is_active方法(不是属性)出现在用户类中,该类如下所示:

class User(db.Model):
    nickname = CharField()
    email = CharField(max_length=150)
    role = IntegerField(default = ROLE_USER)
    about_me = TextField(null = True, max_length=140)
    last_seen = DateTimeField()

    def is_authenticated(self):
        return True

    def is_active(self):
        return True

    def is_anonymous(self):
        return False

    def get_id(self):
        return self.id

    def avatar(self, size):
        return 'http://www.gravatar.com/avatar/' + md5(self.email).hexdigest() + '?d=mm&s=' + str(size)

    def __repr__(self):
        return '<User %r>' % (self.nickname)

但我有点不明白为什么这会让我犯错误。所以我的问题是:有人知道我做错了什么吗?

任何小费都是欢迎的,因为我完全迷路了。。


Tags: selfnonereturnifisemaildef错误
1条回答
网友
1楼 · 发布于 2024-05-15 02:44:06

在街区的任何地方

if user is None:

你真的把任何东西赋给user了吗,所以它仍然是None并且你得到了错误。尝试更改为:

user = User(nickname = nickname, ...)

或打电话

user = User.select().where(User.email == resp.email).first()

if块的末尾

相关问题 更多 >

    热门问题