2017-05-27 25 views
0

嗨,我正在处理简单的瓶子休息api。我在不同的服务器上运行前端和后端。如果我从邮递员访问服务器代码,以下代码有效。如果存在POST方法请求,则无法接受会话变量

from flask import Flask, jsonify, session, request 
import os 

app = Flask(__name__) 
app.config['SECRET_KEY'] = os.urandom(24) 

@app.route('/api/login', methods=['POST']) 
def first(): 
    session['this_one'] = 'first' 
    return jsonify({'message': 'hello', 'success':1}) 


@app.route('/api/messages', methods=['POST']) 
def second(): 
    print session['this_one'] 

    # args = request.json 
    return jsonify({'message':'fdsafd'}) 


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

这里我无法在'second'方法中打印该方法。我得到的错误是'KeyError'

KeyError: 'this_one' 

但是,如果我删除POST方法它工作正常。而且我没有使用会话变量进行复选,代码工作得很好。谁能帮我这个。我们也在回应中使用标题。但是我并没有在这里粘贴这些代码。

非常感谢。

我发布了我用过的html代码。

<!DOCTYPE html> 
<html lang="en"> 
<head> 
    <meta charset="UTF-8"> 
    <title>Title</title> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> 
    <script> 

     $(document).ready(function() { 


    $("#login").click(function() { 
     console.log("1") 
      $.ajax({ 
       type: "POST", 
       url: "http://127.0.0.1:5000/api/login", 
       data: JSON.stringify ({user: 'bbb'}), 
       contentType: "application/json", 
       dataType:"json", 
       crossDomain:true, 

       success: function (data, status, jqXHR) { 
        console.log("success "+data['message']); 
       }, 

       error: function (jqXHR, status) { 
        // error handler 
        console.log(jqXHR); 
        console.log('fail' + status.code); 
       } 
      }); 
    }); 

    $("#go").click(function() { 
     console.log("2") 
     $.ajax({ 
       type: "POST", 
       url: "http://127.0.0.1:5000/api/messages", 
       data: JSON.stringify ({user: 'aaa'}), 
       contentType: "application/json", 
       dataType:"json", 
       crossDomain:true, 

       success: function (data, status, jqXHR) { 
        console.log("success "+data['message']); 
       }, 

       error: function (jqXHR, status) { 
        // error handler 
        console.log(jqXHR); 
        console.log('fail' + status.code); 
       } 
      }); 
    }); 

}); 


    </script> 
</head> 
<body> 
    <button id="login">aaa</button> 
    <button id="go">bbb</button> 
</body> 
</html> 

这是我得到的日志。 jquery发送一个OPTIONS请求。

127.0.0.1 - - [27/May/2017 16:09:45] "OPTIONS /api/login HTTP/1.1" 200 - 
first 
127.0.0.1 - - [27/May/2017 16:09:45] "POST /api/login HTTP/1.1" 200 - 
127.0.0.1 - - [27/May/2017 16:09:52] "OPTIONS /api/messages HTTP/1.1" 200 - 
127.0.0.1 - - [27/May/2017 16:09:52] "POST /api/messages HTTP/1.1" 500 - KeyError 

但是,如果我尝试使用邮递员,我没有看到OPTIONS请求。我相信我应该在Python代码中处理OPTIONS请求。但文件说,烧瓶处理它。

我不知道现在该做什么。有人能帮我吗。

+0

它应该工作我已经测试过127.0.0.1 - [27/May/2017 13:38:53]“POST/api/login HTTP/1.1”200 -' '第一个' '127.0 .0.1 - - [27/May/2017 13:39:01]“POST/api/messages HTTP/1.1”200 -' –

回答

1

它应该工作,我已经验证了您的代码:

127.0.0.1 - - [27/May/2017 13:38:53] "POST /api/login HTTP/1.1" 200 - 
first 
127.0.0.1 - - [27/May/2017 13:39:01] "POST /api/messages HTTP/1.1" 200 - 

我想你POST /api/messages HTTP/1.1在第一时间,那么就会引发错误,因为没有为session['this_one']没有初始化。您应该首先设置"POST /api/login HTTP/1.1"以设置session['this_one'] = 'first',然后您可以在会话中使用它。

更新:

from flask import Flask, jsonify, session, request 
from flask import render_template 
import os 

app = Flask(__name__) 
app.config['SECRET_KEY'] = os.urandom(24) 

@app.route('/') 
def index(): 
    return render_template('index.html') #your html goes here 

@app.route('/api/login', methods=['POST']) 
def first(): 
    session['this_one'] = 'first' 
    return jsonify({'message': 'hello', 'success':1}) 


@app.route('/api/messages', methods=['POST']) 
def second(): 
    print(session['this_one']) 

    # args = request.json 
    return jsonify({'message':'fdsafd'}) 


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

然后运行烧瓶应用程序,你应该保持HTML运行方式烧瓶的应用程序,那么这将是一个web应用程序,然后从这里,你可以看到会话工作,否则就没有会话。

+0

不,我从java脚本调用它,它根本不起作用。我先调用第一种方法,稍后再调用其他方法。你使用卷曲吗? –

+0

那么问题是会话问题。 –

+0

我已经测试过你的api邮差。 –