文本/事件流被视为下载

我已经全部设置好了,没有错误,但是当我转到/ stream页面时,Firefox将其识别为文件并尝试下载。在Safari中,它只是打印出发送的数据。我尝试将代码修改为更简单的实现,其中线程每秒仅产生一些数据,但是产生的结果相同。

我的目标是每次python脚本到达一个循环点时,它将更新Web界面上的进度条。

任何帮助都会很棒。谢谢。

编辑:

app.py

from flask import Flask, render_template, request, Response

app = Flask(__name__)

def event_stream():

event = "Hello!"

yield 'data: %s\n\n' % event

@app.route('/stream')

def stream():

return Response(event_stream(), mimetype="text/event-stream")

if __name__ == "__main__":

app.debug = True

app.run(threaded=True)

index.html

<!DOCTYPE html>

<html>

<head>

<title></title>

<script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<script type="text/javascript">

var source = new EventSource('/stream');

source.onmessage = function (event) {

alert(event.data);

};

</script>

</head>

<body>

<p>Stream page</p>

</body>

</html>

回答:

我已经解决了,但是对于其他遇到相同问题的人:

index.html页面从不实际加载,因为从未在app.py中调用它。完成此操作的方法是转到单独的路由(例如/ page),然后返回send_file('index/html')。这将加载索引页面,创建链接到/ stream的EventSource,然后将在app.py中启动stream方法并产生正确的数据。

通过x每0.2秒增加一个进度条并将其显示在网页上的示例:

app.py

@app.route('/page')

def get_page():

return send_file('templates/progress.html')

@app.route('/progress')

def progress():

def generate():

x = 0

while x < 100:

print x

x = x + 10

time.sleep(0.2)

yield "data:" + str(x) + "\n\n"

return Response(generate(), mimetype= 'text/event-stream')

progress.html

<!DOCTYPE html>

<html>

<head>

<script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css">

<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>

<script>

var source = new EventSource("/progress");

source.onmessage = function(event) {

$('.progress-bar').css('width', event.data+'%').attr('aria-valuenow', event.data);

}

</script>

</head>

<body>

<div class="progress" style="width: 50%; margin: 50px;">

<div class="progress-bar progress-bar-striped active" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100" style="width: 0%"></div>

</div>

</body>

</html>

以上是 文本/事件流被视为下载 的全部内容, 来源链接: utcz.com/qa/410462.html

回到顶部