Python Flask:AttributeError:'NoneType'对象没有属性'is_active'

时间:2014-01-23 22:30:38

标签: python attributes flask attributeerror peewee

使用Flask Mega Tutorial我正在尝试学习Flask。在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'))

由于这段代码之前有效,我不知道为什么现在会出错。 User类中出现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)

但是我有点迷失为什么这会给我一个错误。所以我的问题是:是否有人知道我在这里做错了什么?

欢迎任何提示,因为我完全失去了..

1 个答案:

答案 0 :(得分:3)

在阻止开始的任何地方

if user is None:

你实际上任何内容分配给user,所以它仍然是None并且你得到了错误。尝试更改为:

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

或致电

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

再次在if

的末尾