Flask 的路由Route詳情

前言:

在上一篇Flask 入門Web 微框架Hello Flask中,我們用 Flask 框架寫瞭一個 Hello Flask 應用程序,我們瞭解到 Flask 框架簡潔高效、可以快速上手,接下來將對 Flask 框架的各項功能詳細的介紹一下,本篇文章介紹的是 Flask 的路由(Route)。

1、路由

所謂路由,就是處理請求url和函數之間關系的程序,一個Web應用不同的路徑會有不同的處理函數,當我們請求應用時,路由會根據請求的 url 找到對應處理函數。

2、視圖函數綁定多個url

一個視圖函數可以綁定多個 url,比如下面的代碼把/hi/hello都綁定到hello()函數上,這就會為hello()函數註冊兩個路由,用戶訪問這兩個 url 均會觸發該函數。

在上一篇 Hello Flask 的基礎上,添加下面的函數,並運行程序。

@app.route('/hi')

@app.route('/hello')

def hello():

    return 'Hello Flask!'

3、動態url

Flask 支持在 url 中添加變量部分,使用<變量名>的形式表示,Flask 處理請求時會把變量傳入視圖函數,所以可以在試圖函數內獲取該變量的值。

@app.route('/user/<name>')

def hello_user(name):

    return 'Hello {}!'.format(name)

當我們在瀏覽器中訪問http://127.0.0.1:5000/hello/tigeriaf地址時,將在頁面上看到"Hello tigeriaf!"。url 路徑中/hello/後面的參數被hello()函數的name參數接收並使用。

我們還可以在 url 參數前添加轉換器來轉換參數類型,比如:

@app.route('/user/<int:user_id>')

def hello_user(user_id):

    return 'Hello user:{}!'.format(user_id)

訪問http://127.0.0.1:5000/hello/111,頁面上會顯示"Hello user:111!"。其中,參數類型轉換器int:控制傳入參數的類型隻能是整形,傳入其他類型將報 404 的錯誤,

目前支持的參數類型轉換器有:

  • string:字符型,但是其中不能包含斜杠”/”
  • int:整型
  • float:浮點型
  • uuid:uuid字符類型
  • path:字符型,可以包含斜杠”/”,如aa/bb/cc

除此之外,還可以設置 url 變量參數的默認值,如下,在app.route()裝飾器裡使用defaults參數設置,接收一個字典,來存儲 url 變量參數默認值映射。

@app.route('/user', defaults={'name': 'default_name'})

@app.route('/user/<name>')

def hello_user(name):

    return 'Hello {}!'.format(name)

上述代碼中,/user不帶參數,訪問/user時,變量name就會使用默認值”default_name“。其實,這種做法等同於在hello_user()函數內給name變量設置缺省值。

4、HTTP請求方法設置

HTTP 請求方法常用的有GETPOSTPUTDELETEFlask 路由也可以設置請求方法,在app.route()裝飾器中使用使用methods參數傳入一個包含監聽的 HTTP 請求的可迭代對象。 比如,下面的視圖

函數同時監聽GET請求和POST請求:

from flask import request

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

def login():

    if request.method == 'POST':

        return 'This is a POST request'

    else:

        return 'This is a GET request'

分別使用GET請求和POST請求訪問http://127.0.0.1:5000/login時,會返回不同的內容,如果使用其他的請求方法(如PUT),會報 405 Method Not Allowed 的錯誤。

5、url構建

Flask提供瞭url_for()方法來快速獲取及構建 url,方法的第一個參數是視圖函數的名稱,之後的一個或多個參數對應的是 url 變量部分。

比如:

@app.route('/superuser')

def hello_superuser():

    return 'Hello superuser!'

@app.route('/user/<name>')

def hello_user(name):

    return 'Hello {}!'.format(name)

@app.route('/user/<name>')

def hello(name):

    if name == 'superuser':

        return redirect(url_for('hello_superuser'))

    else:

        return redirect(url_for('hello_user', name=name))

上述代碼中:url_for()方法是根據試圖函數名稱獲取urlredirect()是根據 url 重定向到視圖函數,二者配合使用,用作 url 的重定向。hello(name)函數接受來自 url 的參數的值,判斷值是否與superuser匹配,如果匹配,則使用redirect(url_for())將應用程序重定向到hello_superuser()函數,否則重定向到hello_user()函數。

到此這篇關於Flask 的路由Route詳情的文章就介紹到這瞭,更多相關Flask 的路由Route內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: