在烧瓶应用程序中设置 python dash 仪表板

Posted

技术标签:

【中文标题】在烧瓶应用程序中设置 python dash 仪表板【英文标题】:Setting up a python dash dashboard inside a flask app 【发布时间】:2019-01-27 12:02:18 【问题描述】:

我正在尝试建立一个网站,允许人们在仪表板应用程序中访问不同类型的图表。我希望用户在访问仪表板之前使用用户名和密码登录。这就是我目前所拥有的

from flask import Flask, flash, render_template, request, session
import os, dash
import dash_html_components as html
import dash_core_components as dcc
import flask

app = Flask(__name__)
dash_app = dash.Dash(__name__, server=app, url_base_pathname='/dash_app')
dash_app.config['suppress_callback_exceptions']=True

def index_page():
    index = html.Div([
        dcc.Link('Page 1', href='/page1'),
        html.Br(),
        dcc.Link('Page 2', href='/page2'),
        html.Br(),
        dcc.Link('Page 3', href='/page3'),
        html.Br()
    ])
    return index

dash_app.layout = html.Div(children=[
    dcc.Location(id='url', refresh=False),
    html.Div(id = 'page-content')
])

page_1 = html.Div([
    html.H1('Welcome to page 1'),
    index_page()
])

page_2 = html.Div([
    html.H1('Welcome to page 2'),
    index_page()
])

page_3 = html.Div([
    html.H1('Welcome to page 3'),
    index_page()
])

@dash_app.callback(
    dash.dependencies.Output('page-content','children'),
    [dash.dependencies.Input('url','pathname')]
)
def display_page(pathname):
    if pathname == '/page1':
        return page_1
    if pathname == '/page2':
        return page_2
    if pathname == '/page3':
        return page_3
    else:
        return index_page()

@app.route('/')
def home():
    if not session.get('logged_in'):
        return render_template('login.html')
    else:
        return flask.redirect('/dash_app')


@app.route('/login', methods=['POST'])
def do_admin_login():
    if request.form['password'] == 'password' and request.form['username'] == 'admin':
        session['logged_in'] = True
    else:
        flash('wrong password!')
    return home()

if __name__ == "__main__":
    app.secret_key = os.urandom(12)
    app.run(debug=True, port=5000)

我想解决两个问题:

使用此设置,您无需登录即可访问仪表板。如果您不输入用户名和密码,而是直接转到http://localhost:5000/dash_app,您会立即看到仪表板。我只想向已登录的人授予访问权限。

如果我刷新浏览器页面,在单击三个页面链接之一后,我会收到一条消息“未找到”:我不明白为什么会发生这种情况,我觉得像这样与应用程序的结构有关。

问题:我该如何解决这两个问题?而且,更一般地说;这种结构是否符合我想要实现的目标?这是在烧瓶应用程序中设置仪表板的正确方法吗? (我知道这个登录设置不安全)

编辑:关于刷新问题,我确信它与在烧瓶应用程序中运行的 dash 应用程序有关,因为当我自己运行 dash 应用程序时,我可以刷新 @ 987654323@ 并成功渲染。

【问题讨论】:

【参考方案1】:

您应该使用flask-security 而不是建立自己的登录机制,它可以解决很多问题,例如注册、登录、注销、忘记密码等。

【讨论】:

以上是关于在烧瓶应用程序中设置 python dash 仪表板的主要内容,如果未能解决你的问题,请参考以下文章

类型错误:%d 格式:需要一个数字,而不是 Dash

无法在 Spring Boot 应用程序中设置 hystrix 仪表板

在烧瓶中运行 dash 应用程序

如何在 python(dash)仪表板中显示 png 文件和 csv 表

在 Flask Socket IO 聊天中设置动态聊天室

cpanel中的Python烧瓶应用程序路由:只能访问root url