用戶第一次訪問程序時,服務器會收到一個沒有表單數據的 GET 請求,所以 validate_on_submit() 將返回 False 。 if 語句的內容將被跳過,通過渲染模板處理請求,并傳入表單對象和值為 None 的 name 變量作為參數。用戶會看到瀏覽器中顯示了一個表單
@app.route('/', methods=['GET', 'POST'])
def index():
name = None
form = NameForm()
if form.validate_on_submit():
name = form.name.data
form.name.data = ''
return render_template('index.html', form=form, name=name)
from flask import redirect
....。 redirect() 函數的參數是重定向的 URL,這里使用的重定向URL 是程序的根地址,因此重定向響應本可以寫得更簡單一些,寫成 redirect('/') ,但卻會使用 Flask 提供的 URL 生成函數 url_for() 。推薦使用 url_for() 生成 URL,因為這個函數使用 URL 映射生成 URL,從而保證 URL 和定義的路由兼容,而且修改路由名字后依然可用.
url_for() 函數的第一個且唯一必須指定的參數是端點名,即路由的內部名字。默認情況下,路由的端點是相應視圖函數的名字。在這個示例中,處理根地址的視圖函數是index() ,因此傳給 url_for() 函數的名字是index 。
關系和查詢的處理方式類似。下面這個例子分別從關系的兩端查詢角色和用戶之間的一對
多關系:
>>> users = user_role.users
>>> users
[<User u'susan'>, <User u'david'>]
>>> users[0].role
<Role u'User'>
這個例子中的 user_role.users 查詢有個小問題。執行 user_role.users 表達式時,隱含的
查詢會調用 all() 返回一個用戶列表。 query 對象是隱藏的,因此無法指定更精確的查詢
過濾器。就這個特定示例而言,返回一個按照字母順序排序的用戶列表可能更好。在示例
5-4 中,我們修改了關系的設置,加入了 lazy = 'dynamic' 參數,從而禁止自動執行查詢。
示例 5-4 hello.py :動態關系
class Role(db.Model):
...
users = db.relationship('User', backref='role', lazy='dynamic')
...
這樣配置關系之后, user_role.users 會返回一個尚未執行的查詢,因此可以在其上添加過
濾器:
>>> user_role.users.order_by(User.username).all()
[<User u'david'>, <User u'susan'>]
>>> user_role.users.count()
2
連接到外部SMTP服務器:
示例 6-1 hello.py :配置 Flask-Mail 使用 Gmail
import os
...
app.config['MAIL_SERVER'] = 'smtp.googlemail.com'
app.config['MAIL_PORT'] = 587
app.config['MAIL_USE_TLS'] = True
app.config['MAIL_USERNAME'] = os.environ.get('MAIL_USERNAME')
app.config['MAIL_PASSWORD'] = os.environ.get('MAIL_PASSWORD')
千萬不要把賬戶密令直接寫入腳本,特別是當你計劃開源自己的作品時。為
了保護賬戶信息,你需要讓腳本從環境中導入敏感信息。
保存電子郵件服務器用戶名和密碼的兩個環境變量要在環境中定義。如果你在 Linux 或
Mac OS X 中使用 bash,那么可以按照下面的方式設定這兩個變量:
(venv) $ export MAIL_USERNAME=<Gmail username>
(venv) $ export MAIL_PASSWORD=<Gmail password>