Flask 消息閃現(xiàn)

2022-08-16 10:43 更新

Flask 提供了一個(gè)非常簡(jiǎn)單的方法來(lái)使用閃現(xiàn)系統(tǒng)向用戶反饋信息。閃現(xiàn)系統(tǒng)使得在一個(gè)請(qǐng)求結(jié)束的時(shí)候記錄一個(gè)信息,并且在下次(且僅在下一次中)請(qǐng)求時(shí)訪問(wèn)它,這通常與布局模板結(jié)合使用以公開(kāi)信息。

在 Flask Web 應(yīng)用程序中生成這樣的信息性消息很容易。Flask 框架的閃現(xiàn)系統(tǒng)可以在一個(gè)視圖中創(chuàng)建消息,并在名為 next 的視圖函數(shù)中呈現(xiàn)它。

Flask 模塊包含 flash() 方法。它將消息傳遞給下一個(gè)請(qǐng)求,該請(qǐng)求通常是一個(gè)模板。

flash(message, category)

其中,

  • message 參數(shù)是要閃現(xiàn)的實(shí)際消息。

  • category 參數(shù)是可選的。它可以是“error”,“info”或“warning”。

為了從會(huì)話中刪除消息,模板調(diào)用 get_flashed_messages()。

get_flashed_messages(with_categories, category_filter)

兩個(gè)參數(shù)都是可選的。如果接收到的消息具有類別,則第一個(gè)參數(shù)是元組。第二個(gè)參數(shù)僅用于顯示特定消息。

以下閃現(xiàn)在模板中接收消息。

{% with messages = get_flashed_messages() %}
   {% if messages %}
      {% for message in messages %}
         {{ message }}
      {% endfor %}
   {% endif %}
{% endwith %}

讓我們看一個(gè)簡(jiǎn)單的例子,演示Flask中的閃現(xiàn)機(jī)制。在以下代碼中,'/' URL 顯示登錄頁(yè)面的鏈接,沒(méi)有消息閃現(xiàn)。

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

該鏈接會(huì)將用戶引導(dǎo)到'/login' URL,該 URL 顯示登錄表單。提交時(shí),login() 視圖函數(shù)驗(yàn)證用戶名和密碼,并相應(yīng)閃現(xiàn) 'success' 消息或創(chuàng)建 'error' 變量。

@app.route('/login', methods = ['GET', 'POST'])
def login():
    error = None

if request.method == 'POST': if request.form['username'] != 'admin' or request.form['password'] != 'admin': error = 'Invalid username or password. Please try again!' else: flash('You were successfully logged in') return redirect(url_for('index')) return render_template('login.html', error = error)

如果出現(xiàn)錯(cuò)誤,則會(huì)重新顯示登錄模板,并顯示錯(cuò)誤消息。

login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Login</title>
</head>
<body>
    <form method = "post" action = "http://localhost:5000/login">
        <table>
            <tr>
                <td>Username</td>
                <td><input type = 'username' name = 'username'></td>
            </tr>
            <tr>
                <td>Password</td>
                <td><input type = 'password' name = 'password'></td>
            </tr>
            <tr>
                <td><input type = "submit" value = "Submit"></td>
            </tr>
        </table>
    </form>
    {% if error %}
        <p><strong>Error</strong>: {{ error }}</p>
    {% endif %}
</body>
</html>

另一方面,如果登錄成功,則會(huì)在索引模板上刷新成功消息。

Index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Index</title>
</head>
<body>
    {% with messages = get_flashed_messages() %}
         {% if messages %}
               {% for message in messages %}
                    <p>{{ message }}</p>
               {% endfor %}
         {% endif %}
    {% endwith %}
<h3>Welcome!</h3>
<a href = "{{ url_for('login') }}">login</a>
</body>
</html>

下面給出了 Flask 消息閃現(xiàn)示例的完整代碼:

Flash.py

from flask import Flask, flash, redirect, render_template, request, url_for
app = Flask(__name__)
app.secret_key = 'random string'

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

@app.route('/login', methods = ['GET', 'POST']) def login(): error = None

if request.method == 'POST': if request.form['username'] != 'admin' or request.form['password'] != 'admin': error = 'Invalid username or password. Please try again!' else: flash('You were successfully logged in') return redirect(url_for('index'))

return render_template('login.html', error = error)

if __name__ == '__main__':

    app.run(debug=True)

執(zhí)行上述代碼后,您將看到如下所示的界面。

Flask Message Flashing Example

當(dāng)您點(diǎn)擊鏈接,您將被定向到登錄頁(yè)面。

輸入用戶名和密碼。

Login Page

點(diǎn)擊登錄。將顯示一條消息“您已成功登錄”。

Successfully Logged in Page


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)