Flask / Werkzeug, как вернуть предыдущую страницу после входа в систему - PullRequest
22 голосов
/ 10 сентября 2010

Я использую микро-фреймворк Flask, основанный на Werkzeug, который использует Python.

Перед каждой запрещенной страницей есть декоратор, который гарантирует, что пользователь вошел в систему, и в настоящее время возвращает его на страницу входаесли они не вошли в систему, например так:

# Decorator
def logged_in(f):
    @wraps(f)
    def decorated_function(*args, **kwargs):
        try:
            if not session['logged_in']:
                flash('Please log in first...', 'error')
                return redirect(url_for('login'))
            else:
                return f(*args, **kwargs)
        except KeyError:
            flash('Please log in first...', 'error')
            return redirect(url_for('login'))
    return decorated_function


# Login function
@app.route('/', methods=['GET', 'POST'])
def login():
    """Login page."""
    if request.method=='POST':
    ### Checks database, etc. ###
    return render_template('login.jinja2')


# Example 'restricted' page
@app.route('/download_file')
@logged_in
def download_file():
    """Function used to send files for download to user."""
    fileid = request.args.get('id', 0)
    ### ... ###

После входа в систему необходимо вернуть пользователей на страницу, которая перевела их на страницу входа.Также необходимо сохранить такие вещи, как переданные переменные (т. Е. Вся ссылка в основном www.example.com/download_file?id=3)

Кто-нибудь знает, как это сделать?

Спасибо за помощь: -)

Ответы [ 2 ]

22 голосов
/ 10 сентября 2010

Я думаю, что стандартной практикой является добавление URL-адреса, на который пользователь должен быть перенаправлен после успешного входа, в конец строки запроса URL-адреса входа.

Вы бы изменили свой декоратор на что-то вроде этого (с удалением избыточности в вашей функции декоратора):

def logged_in(f):
    @wraps(f)
    def decorated_function(*args, **kwargs):
        if session.get('logged_in') is not None:
            return f(*args, **kwargs)
        else:
            flash('Please log in first...', 'error')
            next_url = get_current_url() # However you do this in Flask
            login_url = '%s?next=%s' % (url_for('login'), next_url)
            return redirect(login_url)
    return decorated_function

Вам придется заменить что-то на get_current_url(), потому что я не знаю, как это делается во Flask.

Затем в обработчике входа в систему, когда пользователь успешно вошел в систему, вы проверяете, есть ли в запросе параметр next, и, если это так, перенаправляете их на этот URL-адрес. В противном случае вы перенаправляете их на какой-то URL по умолчанию (обычно /, наверное).

11 голосов
/ 11 сентября 2010

Вы можете использовать строку запроса, чтобы сохранить информацию о файле без изменений в течение одного или двух кликов.Одна из приятных особенностей url_for заключается в том, что он передает неизвестные параметры в виде строк запроса .Таким образом, не слишком сильно изменяя свою регистрационную страницу, вы можете сделать что-то вроде этого:

def login_required(f):
    @wraps(f)
    def decorated_function(*args, **kwargs):
        if g.user is None:
            return redirect(url_for('register', wantsurl = request.path))
        return f(*args, **kwargs)
    return decorated_function

Здесь wantsurl будет отслеживать URL-адрес, на который приземлился пользователь.Если незарегистрированный пользователь перейдет на /download/some/file.txt, login_required отправит вам на /register?wantsurl=%2Fdownload%2Fsome%2Ffile.txt Затем вы добавите пару строк в вашу функцию регистрации:

@app.route('/register', methods=['GET', 'POST'])
def register():
    if request.method == 'GET':
        if 'wantsurl' in request.args:
            qs = request.args['wantsurl']
            return render_template('register.html', wantsurl=qs)
    if request.method == 'POST':
        if 'wantsurl' in request.form and everything_else_ok:
            return redirect(request.form['wantsurl'])

Это автоматически перенаправит вас на загрузку при успешномрегистрация, при условии, что у вас есть что-то в форме с именем 'wanturl' со значением qs, или вы можете отправить свою форму со строкой запроса;это может быть немного, если-иначе в шаблоне.

...