Python Flask-login AttributeError: 'User' 对象没有属性 'is_active'

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/26606391/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-08-19 00:45:13  来源:igfitidea点击:

Flask-login AttributeError: 'User' object has no attribute 'is_active'

pythonflaskflask-login

提问by bartezr

I have a problem with flask-login. After filling login form and clicking 'Submit' i'm get this error:

我有烧瓶登录的问题。填写登录表单并单击“提交”后,我收到此错误:

Flask-login AttributeError: 'User' object has no attribute 'is_active'

Flask-login AttributeError: 'User' 对象没有属性 'is_active'

Some test users are created. And no problems with login template

创建了一些测试用户。并且登录模板没有问题

Traceback:

追溯:

    Traceback (most recent call last):
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1836, in __call__
return self.wsgi_app(environ, start_response)
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1820, in wsgi_app
response = self.make_response(self.handle_exception(e))
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1403, in handle_exception
reraise(exc_type, exc_value, tb)
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1817, in wsgi_app
response = self.full_dispatch_request()
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1477, in full_dispatch_request
rv = self.handle_user_exception(e)
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1381, in handle_user_exception
reraise(exc_type, exc_value, tb)
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1475, in full_dispatch_request
rv = self.dispatch_request()
File "C:\flask_prj\project\venv\lib\site-packages\flask\app.py", line 1461, in dispatch_request
return self.view_functions[rule.endpoint](**req.view_args)
File "C:\flask_prj\project\hello.py", line 170, in login
login_user(user, form.remember_me.data)
File "C:\flask_prj\project\venv\lib\site-packages\flask_login.py", line 576, in login_user
if not force and not user.is_active():
AttributeError: 'User' object has no attribute 'is_active'

My code in views:

我在视图中的代码:

@app.route('/login', methods=['GET', 'POST'])
def login():
    form = LoginForm()
    if form.validate_on_submit():
        user = User.query.filter_by(email=form.email.data).first()
        if user is not None and user.verify_password(form.password.data):
            login_user(user, form.remember_me.data)
            return redirect(request.args.get('next') or url_for('index'))
        flash('Invalid username or password.')
    return render_template('login.html', form=form)
@login_required
def logout():
    logout_user()
    flash ('You have been logged out')
    return redirect(url_for('index'))

My model:

我的型号:

class User(db.Model):
    __tablename__ = 'users'
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.Integer, unique=True, index=True)
    email = db.Column(db.String(64), unique=True, index=True)
    password_hash = db.Column(db.String(128))
    @property
    def password(self):
        raise AttributeError('password is not a readable attribute')
    @password.setter
    def password(self, password):
        self.password_hash = generate_password_hash(password)
    def verify_password(self, password):
        return check_password_hash(self.password_hash, password)
    role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))
    def __repr__(self):
        return '<User %r>' % self.username

采纳答案by corvid

You should subclass UserMixinon your model. You should also add a user_loader

您应该UserMixin对模型进行子类化。您还应该添加一个 user_loader

from flask.ext.login import UserMixin
from yourapp import login_manager

@login_manager.user_loader
def get_user(ident):
  return User.query.get(int(ident))


class User(db.Model, UserMixin):
  id = db.Column(db.Integer, primary_key=True)
  ### yada yada, you know what goes here

回答by Leandro Poblet

From the Flask-login documentation, it specifically says:

Flask-login 文档中,它特别指出:

"To make implementing a user class easier, you can inherit from UserMixin, which provides default implementations for all of these methods. (It's not required, though."

“为了更轻松地实现用户类,您可以从 UserMixin 继承,它为所有这些方法提供默认实现。(但这不是必需的。”

The methods refered will be: is_authenticated(), is_active(), is_anonymous()and get_id(), which by the look of your model, they are missing. Once you implement those functions to your model, there should be no problem with Flask-login.

引用的方法将是:is_authenticated()is_active()is_anonymous()get_id(),从您的模型来看,它们是缺失的。一旦您将这些功能实现到您的模型中,Flask-login 应该没有问题。