1

我正在尝试使用 Flask-JWT 为网站创建后端,因此我处于身份验证部分。

我从那个链接开始:

https://pythonhosted.org/Flask-JWT/

以提供的代码为例。

但我试图将它与包含凭据的数据库链接,所以这里是使用我的数据库函数“更干净”的代码:

(要理解,Identification.login 的主要功能是检查用户/密码是否在数据库中,并返回登录信息(错误的用户,错误的密码,成功)+数据库中的用户 ID)

from flask import Flask
from flask_jwt import JWT, jwt_required, current_identity
from Identification.login import main #Function that test password within database


class User(object):
    def __init__(self, id, username, password):
        self.id = id
        self.username = username
        self.password = password


def authenticate(username, password):
    result = main(username, password)
    if result['value'] == 0:
        return User(result['id'], username, password)


def identity(payload):
    # TODO
    # user_id = payload['identity']
    # return userid_table.get(user_id, None)


app = Flask(__name__)
app.debug = True
app.config['SECRET_KEY'] = 'super-secret'

jwt = JWT(app, authenticate, identity)


@app.route('/protected')
@jwt_required()
def protected():
    return '%s' % current_identity


if __name__ == '__main__':
    app.run()

我的问题是关于身份功能:我不明白我需要如何管理它。从该站点的示例中,参数是简单的“有效负载”,但不知道它到底是什么。我唯一的描述是:https ://pythonhosted.org/Flask-JWT/_modules/flask_jwt.html#JWT

所以我的问题是我如何需要用户身份功能?在我的例子中,我应该如何适应它?

另外,如果您有关于 flask-jwt 的清晰文档,可以清楚地理解这个模块,那将是一个很大的帮助

谢谢

4

1 回答 1

2

正如此响应中所指出的,您正在查看的 Flask-JWT 库自 2015 年以来一直没有更新。相反,可在此处找到的 Flask-JWT-Extended已更新更新,并且具有更好的文档。

于 2020-12-15T15:55:23.857 回答