我正在尝试使用 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 的清晰文档,可以清楚地理解这个模块,那将是一个很大的帮助
谢谢