我有一个jQuery Ajax调用,如下所示:
$("#tags").keyup(function(event) {
$.ajax({url: "/terms",
type: "POST",
contentType: "application/json",
data: JSON.stringify({"prefix": $("#tags").val() }),
dataType: "json",
success: function(response) { display_terms(response.terms); },
});
我有一个像这样的Flask方法:
@app.route("/terms", methods=["POST"])
def terms_by_prefix():
req = flask.request.json
tlist = terms.find_by_prefix(req["prefix"])
return flask.jsonify({'terms': tlist})
tcpdump显示HTTP对话框:
POST /terms HTTP/1.1
Host: 127.0.0.1:5000
User-Agent: Mozilla/5.0 (X11; Linux i686; rv:12.0) Gecko/20100101 Firefox/12.0
Accept: application/json, text/javascript, */*; q=0.01
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Type: application/json; charset=UTF-8
X-Requested-With: XMLHttpRequest
Referer: http://127.0.0.1:5000/
Content-Length: 27
Pragma: no-cache
Cache-Control: no-cache
{"prefix":"foo"}
然而,Flask回复没有保持活着。
HTTP/1.0 200 OK
Content-Type: application/json
Content-Length: 445
Server: Werkzeug/0.8.3 Python/2.7.2+
Date: Wed, 09 May 2012 17:55:04 GMT
{"terms": [...]}
是不是实际上没有实现keep-alive?
答案 0 :(得分:20)
默认的request_handler是WSGIRequestHandler。
在app.run()
之前,添加一行,
WSGIRequestHandler.protocol_version = "HTTP/1.1"
不要忘记from werkzeug.serving import WSGIRequestHandler
。
答案 1 :(得分:7)
Werkzeug的集成Web服务器构建于Python标准库的BaseHTTPServer之上。如果将HTTP协议版本设置为1.1,BaseHTTPServer似乎支持Keep-Alives。
Werkzeug不会这样做,但是如果你准备好攻击Flask用来实例化Werkzeug的BaseWSGIServer的机器,你可以自己动手。请参阅调用Flask.run()
的{{1}}。你要做的就归结为werkzeug.serving.run_simple()
。
我没有测试过这个解决方案。我想你确实知道Flask的web服务器应该只用于开发。