Как объединить логин Flask с приложением Dash?

1

Я должен разработать веб-приложение, которое предоставляет услуги Flask и Dash. Например, я хотел бы создать логин в Flask в сочетании с приложением Dash. Проблема в том, что я не могу связать логин колбы с тире. Мне нужен такой метод, как '@require_login', который фильтрует доступ даже к сервисам Dash. Код выглядит следующим образом:

app_flask = Flask(__name__)

app_flask.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////login.db'
app_flask.config['SECRET_KEY'] = 'thisissecret'

db = SQLAlchemy(app_flask)
login_manager = LoginManager()
login_manager.init_app(app_flask)

class User(UserMixin, db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(30), unique=True)

@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))

@app_flask.route('/')
def index():
    user = User.query.filter_by(username='admin').first()
    login_user(user)
    return 'You are now logged in!'

@app_flask.route('/logout')
@login_required
def logout():
    logout_user()
    return 'You are now logged out!'

@app_flask.route('/home')
@login_required
def home():
    return 'The current FLASK user is ' + current_user.username

# TODO how to add login_required for dash? 
app_dash = Dash(server=app_flask, url_base_pathname='/dash/')
app_dash.layout = html.H1('MY DASH APP')


if __name__ == '__main__':
    app_dash.run_server(debug=True)
Теги:
flask
web-applications
dash

2 ответа

1

Эта строка app_dash = Dash(server=app_flask, url_base_pathname='/dash/'), создает новые функции view_functions в app_flask идентифицируемые по его url_base_pathname.

Вы можете отлаживать и проверять значение app_flask.view_functions до и после создания app_dash.

Теперь, когда мы знаем, какие view_functions созданы app_dash, мы можем применить к ним login_required вручную.

for view_func in app_flask.view_functions:
    if view_func.startswith(app_dash.url_base_pathname):
        app_flask.view_functions[view_func] = login_required(app_flask.view_functions[view_func])
Конечные точки 'app_dash' теперь будут защищены.
  • 0
    Салют тебе! ОНО РАБОТАЕТ
0

Решение: сеанс из фляжки (работа с файлом cookie)

from flask import session

это пример:

@login_manager.user_loader def load_user(user_id): # я think here it good session["uid"] = user_id return User.query.get(int(user_id))

# TODO how to add login_required for dash? if "uid" in session: app_dash = Dash(server=app_flask, url_base_pathname='/dash/') app_dash.layout = html.H1('MY DASH APP')

  • 0
    Спасибо за ответ. Таким образом, однако, сеансы используются вне контекста. «RuntimeError: Работа вне контекста запроса. Обычно это означает, что вы пытались использовать эту функцию в качестве активного HTTP-запроса. Информацию о том, как избежать этой проблемы, можно найти в документации по тестированию.» Возможным решением может быть сохранение сеанса в база данных. Как вы думаете, это лучше всего сделать? Или я что-то не так делаю?
  • 0
    Это решение, но я думаю, что это слишком много, если это небольшое приложение, может быть, вы не используете Flask-Login, но только для сессии? если вы хотите использовать Flask-Login, как это, может быть, вы найдете другой способ реализовать это?
Показать ещё 1 комментарий

Ещё вопросы

Сообщество Overcoder
Наверх
Меню