2

我有一个现有的 Flask 网络应用程序,我想将一个现有的 Dash 应用程序(一个 Plotly Flask 应用程序)合并到其中。正如Flask 的文档所建议的那样,我正在使用DispatcherMiddleware它来实现这一点:

flask_app = Flask(__name__) # App with both apps attached to it 
app = Flask(__name__) # Existing Flask App 
dash_app = Dash(__name__) # Dash app 

dash_app.config.supress_callback_exceptions = True

# Use DispatcherMiddleware to route separate apps into one
flask_app.wsgi_app = DispatcherMiddleware(app, {'/dash': dash_app.server})

我们最终运行flask_app

if __name__ == "__main__":
    flask_app.run(debug=True)

但是,当我前往 时127.0.0.1:<port>/dash/,网页上出现以下错误:

在此处输入图像描述

我在控制台日志中看到以下内容:

127.0.0.1 - - [30/Aug/2017 11:11:02] "GET /dash HTTP/1.1" 301 -
127.0.0.1 - - [30/Aug/2017 11:11:02] "GET /dash/ HTTP/1.1" 200 -
127.0.0.1 - - [30/Aug/2017 11:11:03] "GET /_dash-layout HTTP/1.1" 404 -
127.0.0.1 - - [30/Aug/2017 11:11:03] "GET /_dash-dependencies HTTP/1.1" 404 

如何让布局为我的 Dash 应用程序正确加载?

4

1 回答 1

4

这就是我克服这个问题的方法。不漂亮但有效。

你需要运行.py:

from werkzeug.wsgi import DispatcherMiddleware
from werkzeug.serving import run_simple
from server import server
from dash_app  import app as app1
from flask_app import app as app2

app = DispatcherMiddleware(server, 
                           {'/myflaskapp': app2})
if __name__ == '__main__':
    run_simple('localhost', 5000, app, use_reloader=True)

您的 server.py 将如下所示:

from flask import Flask, render_template

server = Flask(__name__)

@server.route('/')
def server_root():
    return render_template('index.html')

你的 dash_app.py:

import dash
from server import server
app = dash.Dash(name='mydash', sharing=True, server=server, url_base_pathname='/mydash')

最后是你的 flask_app.py:

from flask import Flask
app = Flask(__name__)
@app.route("/news")
def news():
    return render_template('news.html')

您的 flask_app 位于 /myflaskapp/news

您的 dash_app 位于 /mydash

于 2017-09-15T17:07:30.377 回答