79

仕組みを理解しようとしてFlask-Loginいます。

ドキュメントで、事前に入力されたユーザーのリストを使用していることがわかります。データベースに保存されたユーザー リストを操作したい。

Flask-Loginただし、このモジュールでいくつかのことがわかりません。

@login_manager.user_loader
def load_user(userid):
    #print 'this is executed',userid
    return user(userid, 'asdf')

このコードはすべてのリクエストで呼び出されますか? これは、ユーザー オブジェクトのすべての詳細を読み込むために使用されますか?

今のところ、私はこのコードを持っています:

@app.route('/make-login')
def make_login():
    username = 'asdf'
    password = 'asdf'
    user_data = authenticate(username, password)
    user_obj = user(user_data[0], user_data[1])
    login_user(user_obj)
    return render_template('make-login.html')

/make-login にアクセスしたらログインしたい。

私のユーザークラス:

class user(object):
    def __init__(self, id, username, active=True):
        self.username = username
        self.id = id
        #self.active = active
    def is_authenticated(self):
        return True  

    def is_active(self):
        return True

    def is_anonymous(self):
        return False

    def get_id(self):
        return 5

また、認証/登録用に別の 2 つの関数を作成しました。

def authenticate(username, password):

    cursor = db.cursor()
    password = md5.md5(password).hexdigest()
    try:
        query = "SELECT * FROM `users` WHERE `username` = %s AND `password` = %s"
        cursor.execute(query, (username, password))
        results = cursor.fetchall()
        #print results[0][0]
        #print "here i am"
        if not results:
            return False
        else:
            user_data = [results[0][0], results[0][1]]
            return user_data
            #self.authenticated = True
            #self.user_id = results[0][0]
            #session['username']  = results['username']
            #print type(results)
    except db.Error, e:
        return 'There was a mysql error'    

def register(username, password, email, *args):
    cursor = db.cursor()
    password = md5.md5(password).hexdigest()
    try:
        #query = "INSERT INTO `users` (`username`, `password`, `email`) VALUES ('%s', '%s', '%s')" % (username, password, email)
        query = "INSERT INTO `users` (`username`, `password`, `email`) VALUES (%s, %s, %s)"
        cursor.execute(query, (username, password, email))
        db.commit()
        return True
    except db.Error, e:
        print 'An error has been passed. %s' %e
        db.rollback()
        return False

Flask-Loginこれを MySQL で機能させる方法がわかりません。また、ユーザーがログインしているかどうかもわかりません。ユーザー ID またはユーザー名を取得するにはどうすればよいですか?

これがどのように機能するかを誰かがいくつかの行で説明できますFlask-Loginか?

4

6 に答える 6

80

Flask-login には実際にはユーザー バックエンドはありません。ユーザーのログインとログアウトを支援するセッション機構を処理するだけです。ユーザーを表すものを (メソッドを装飾することによって) 伝える必要があり、ユーザーが「アクティブ」であるかどうかを知る方法もあなた次第です (「アクティブ」であるということは、アプリケーションによって異なることを意味する可能性があるためです)。 )。

ドキュメントを読んで、それが何をし、何をしないのかを確認してください。ここでは、db バックエンドとの接続にのみ集中します。

まず、ユーザー オブジェクトを定義します。ユーザーのプロパティを表します。このオブジェクトは、データベースや LDAP などにクエリを実行できます。これは、ログイン メカニズムをデータベース バックエンドに接続するフックです。

この目的のために、ログイン例のスクリプトを使用します。

class User(UserMixin):
    def __init__(self, name, id, active=True):
        self.name = name
        self.id = id
        self.active = active

    def is_active(self):
        # Here you should write whatever the code is
        # that checks the database if your user is active
        return self.active

    def is_anonymous(self):
        return False

    def is_authenticated(self):
        return True

ユーザー オブジェクトを作成したら、ユーザーをロードするメソッドを記述する必要があります (基本的に、User上記のクラスのインスタンスを作成します)。このメソッドは、ユーザー ID で呼び出されます。

@login_manager.user_loader
def load_user(id):
     # 1. Fetch against the database a user by `id` 
     # 2. Create a new object of `User` class and return it.
     u = DBUsers.query.get(id)
    return User(u.name,u.id,u.active)

これらの手順が完了すると、ログイン方法は次のようになります。

  1. ユーザー名とパスワードが (データベースに対して) 一致するかどうかを確認します。このコードは自分で記述する必要があります。

  2. 認証が成功した場合は、ユーザーのインスタンスをに渡す必要がありますlogin_user()

于 2012-08-22T21:38:17.337 に答える
16

Flask-login は、すべてのリクエストの前にユーザーをロードしようとします。はい、以下のサンプルコードはすべてのリクエストの前に呼び出されます。現在のセッションのユーザー ID を確認するために使用され、その ID のユーザー オブジェクトをロードします。

@login_manager.user_loader
def load_user(userid):
    #print 'this is executed',userid
    return user(userid, 'asdf')        

github の Flask-login ソース コードを見ると、関数 init_app の下に次の行があります。

app.before_request(self._load_user)

したがって、すべてのリクエストの前に、_load_user 関数が呼び出されます。_load_user 関数は、実際には条件に基づいて別の関数「reload_user()」を呼び出します。最後に、reload_user() 関数は、作成したコールバック関数を呼び出します (例では load_user() )。

また、flask-login は、ユーザーをログイン/ログアウトするメカニズムのみを提供します。mysql データベースを使用しているかどうかは気にしません。

于 2012-08-22T22:28:36.560 に答える
0

ログインを使用するFlaskの例を次に示します。https : //bitbucket.org/leafstorm/flask-login/src/3160dbfc7cfc/example/login-example.pyログインが必要なすべてのメソッドに@login_requiredを使用する必要があります。例えば、

@app.route('/make-login')
@login_required
def make_login():
    ...
于 2012-08-22T17:25:25.130 に答える