我尝试设置一个类别的API登录,当登录成功时,它会返回一个JWT以及从POST请求登录时发送的名/姓。我的问题是我无法弄清楚一种方法可以将名字/姓氏变量返回到另一个类和函数。这是我的代码:
@app.route('/login', methods=['POST'])
def login():
if not request.is_json:
return jsonify({"msg": "Missing JSON in request"}), 400
username = request.json.get('username', None)
password = request.json.get('password', None)
client_fname = request.json.get('Client First Name', None)
client_lname = request.json.get('Client Last Name', None)
if not username:
return jsonify({"msg": "Missing username parameter"}), 400
if not password:
return jsonify({"msg": "Missing password parameter"}), 400
if username != USER_DATA.get(username) and password not in USER_DATA[username]:
return jsonify({"msg": "Bad username or password"}), 401
access_token = create_access_token(identity=username)
return jsonify(access_token=access_token), 200, PrivateResource.sendData(self, client_fname, client_lname)
class PrivateResource(Resource):
@app.route('/protected', methods=['GET'])
@jwt_required
def sendData(self, client_fname, client_lname):
return mysqldb.addUser("{}".format(client_fname),"{}".format(client_lname))
我想返回client_fname
和client_lname
,以便我可以将其与sendData()
一起使用。如何在没有来自json的unicode或传递变量的问题的情况下实现这一目标?
答案 0 :(得分:0)
我认为你需要的是一个Session然后你可以做这样的事情 -
@app.route('/login', methods=['GET', 'POST'])
def login():
if request.method == 'POST']
session['username'] = request.form['user']
return redirect(url_for('home'))
在家庭使用的路上 -
@app.route('/home')
def home():
if 'username' in session:
return render_template("index.html", name=session['username'])
希望这有帮助
答案 1 :(得分:0)
您可以使用会话来存储跨函数访问所需的变量。将这些添加到登录,
session['client_fname'] = request.json.get('Client First Name', None)
session['client_lname'] = request.json.get('Client Last Name', None)
从sendData访问它:
return mysqldb.addUser("{}".format(session['client_fname']),"{}".format(session['client_lname']))
希望这能回答你的问题。