如何返回JSON请求输入并在另一个函数中使用它?

时间:2018-06-05 20:01:52

标签: python mysql json flask

我尝试设置一个类别的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_fnameclient_lname,以便我可以将其与sendData()一起使用。如何在没有来自json的unicode或传递变量的问题的情况下实现这一目标?

2 个答案:

答案 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']))

希望这能回答你的问题。