前言:
在上一篇Flask 入門(mén)Web 微框架Hello Flask中,我們用 Flask 框架寫(xiě)了一個(gè) Hello Flask 應(yīng)用程序,我們了解到 Flask 框架簡(jiǎn)潔高效、可以快速上手,接下來(lái)將對(duì) Flask 框架的各項(xiàng)功能詳細(xì)的介紹一下,本篇文章介紹的是 Flask 的路由(Route)。
1、路由
所謂路由,就是處理請(qǐng)求url
和函數(shù)之間關(guān)系的程序,一個(gè)Web應(yīng)用不同的路徑會(huì)有不同的處理函數(shù),當(dāng)我們請(qǐng)求應(yīng)用時(shí),路由會(huì)根據(jù)請(qǐng)求的 url
找到對(duì)應(yīng)處理函數(shù)。
2、視圖函數(shù)綁定多個(gè)url
一個(gè)視圖函數(shù)可以綁定多個(gè) url
,比如下面的代碼把/hi
和/hello
都綁定到hello()
函數(shù)上,這就會(huì)為hello()
函數(shù)注冊(cè)兩個(gè)路由,用戶訪問(wèn)這兩個(gè) url 均會(huì)觸發(fā)該函數(shù)。
在上一篇 Hello Flask 的基礎(chǔ)上,添加下面的函數(shù),并運(yùn)行程序。
1
2
3
4
5
6
7
|
@app .route( '/hi' ) @app .route( '/hello' ) def hello(): return 'Hello Flask!' |
3、動(dòng)態(tài)url
Flask
支持在 url 中添加變量部分,使用<變量名>的形式表示,Flask
處理請(qǐng)求時(shí)會(huì)把變量傳入視圖函數(shù),所以可以在試圖函數(shù)內(nèi)獲取該變量的值。
1
2
3
4
5
|
@app .route( '/user/<name>' ) def hello_user(name): return 'Hello {}!' . format (name) |
當(dāng)我們?cè)跒g覽器中訪問(wèn)http://127.0.0.1:5000/hello/tigeriaf
地址時(shí),將在頁(yè)面上看到"Hello tigeriaf!"
。url 路徑中/hello/
后面的參數(shù)被hello()
函數(shù)的name
參數(shù)接收并使用。
我們還可以在 url 參數(shù)前添加轉(zhuǎn)換器來(lái)轉(zhuǎn)換參數(shù)類(lèi)型,比如:
1
2
3
4
5
|
@app .route( '/user/<int:user_id>' ) def hello_user(user_id): return 'Hello user:{}!' . format (user_id) |
訪問(wèn)http://127.0.0.1:5000/hello/111
,頁(yè)面上會(huì)顯示"Hello user:111!"
。其中,參數(shù)類(lèi)型轉(zhuǎn)換器int:
控制傳入?yún)?shù)的類(lèi)型只能是整形,傳入其他類(lèi)型將報(bào) 404 的錯(cuò)誤,
目前支持的參數(shù)類(lèi)型轉(zhuǎn)換器有:
-
string
:字符型,但是其中不能包含斜杠"/" -
int
:整型 -
float
:浮點(diǎn)型 -
uuid:uuid
字符類(lèi)型 -
path
:字符型,可以包含斜杠"/",如aa/bb/cc
除此之外,還可以設(shè)置 url 變量參數(shù)的默認(rèn)值,如下,在app.route()
裝飾器里使用defaults
參數(shù)設(shè)置,接收一個(gè)字典,來(lái)存儲(chǔ) url 變量參數(shù)默認(rèn)值映射。
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不帶參數(shù),訪問(wèn)/user
時(shí),變量name
就會(huì)使用默認(rèn)值"default_name
"。其實(shí),這種做法等同于在hello_user()
函數(shù)內(nèi)給name
變量設(shè)置缺省值。
4、HTTP請(qǐng)求方法設(shè)置
HTTP 請(qǐng)求方法常用的有GET
、POST
、PUT
、DELETE
。Flask
路由也可以設(shè)置請(qǐng)求方法,在app.route()
裝飾器中使用使用methods
參數(shù)傳入一個(gè)包含監(jiān)聽(tīng)的 HTTP 請(qǐng)求的可迭代對(duì)象。 比如,下面的視圖
函數(shù)同時(shí)監(jiān)聽(tīng)GET請(qǐng)求和POST請(qǐng)求:
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請(qǐng)求和POST
請(qǐng)求訪問(wèn)http://127.0.0.1:5000/login
時(shí),會(huì)返回不同的內(nèi)容,如果使用其他的請(qǐng)求方法(如PUT),會(huì)報(bào) 405 Method Not Allowed
的錯(cuò)誤。
5、url構(gòu)建
Flask
提供了url_for()
方法來(lái)快速獲取及構(gòu)建 url
,方法的第一個(gè)參數(shù)是視圖函數(shù)的名稱(chēng),之后的一個(gè)或多個(gè)參數(shù)對(duì)應(yīng)的是 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()
方法是根據(jù)試圖函數(shù)名稱(chēng)獲取url
,redirect()
是根據(jù) url
重定向到視圖函數(shù),二者配合使用,用作 url
的重定向。hello(name)
函數(shù)接受來(lái)自 url 的參數(shù)的值,判斷值是否與superuser
匹配,如果匹配,則使用redirect(url_for())
將應(yīng)用程序重定向到hello_superuser()
函數(shù),否則重定向到hello_user()
函數(shù)。
到此這篇關(guān)于Flask 的路由Route詳情的文章就介紹到這了,更多相關(guān)Flask 的路由Route內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!
原文鏈接:https://juejin.cn/post/7029474639948546061