前言:
在上一篇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 的基礎上,添加下面的函數,并運行程序。
1
2
3
4
5
6
7
|
@app .route( '/hi' ) @app .route( '/hello' ) def hello(): return 'Hello Flask!' |
3、動態url
Flask
支持在 url 中添加變量部分,使用<變量名>的形式表示,Flask
處理請求時會把變量傳入視圖函數,所以可以在試圖函數內獲取該變量的值。
1
2
3
4
5
|
@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 參數前添加轉換器來轉換參數類型,比如:
1
2
3
4
5
|
@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 變量參數默認值映射。
1
2
3
4
5
6
7
|
@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 請求方法常用的有GET
、POST
、PUT
、DELETE
。Flask
路由也可以設置請求方法,在app.route()
裝飾器中使用使用methods
參數傳入一個包含監聽的 HTTP 請求的可迭代對象。 比如,下面的視圖
函數同時監聽GET請求和POST請求:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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
變量部分。
比如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
@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()
方法是根據試圖函數名稱獲取url
,redirect()
是根據 url
重定向到視圖函數,二者配合使用,用作 url
的重定向。hello(name)
函數接受來自 url 的參數的值,判斷值是否與superuser
匹配,如果匹配,則使用redirect(url_for())
將應用程序重定向到hello_superuser()
函數,否則重定向到hello_user()
函數。
到此這篇關于Flask 的路由Route詳情的文章就介紹到這了,更多相關Flask 的路由Route內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://juejin.cn/post/7029474639948546061