新聞中心
說(shuō)到web開發(fā)框架,小編平常用Flask和Django的比較多,其中的Flask屬于是輕量級(jí)的開發(fā)框架,寫一個(gè)API接口也是十分地方便,不過(guò)今天我們要介紹的框架FastAPI同樣在Python開發(fā)者當(dāng)中有著較好地口碑,那么在開始之前,我們先要安裝好需要用到的模塊,通過(guò)pip命令。

pip install fastapi
而ASGI服務(wù)器可以使用uvicorn,那么同樣地。
pip install uvicorn
HelloWorld
我們先嘗試用Flask框架來(lái)寫一個(gè)HelloWorld,代碼如下:?
from flask import Flask, request
import json
app = Flask(__name__)
@app.route('/')
def hello_world():
return 'hello world'
if __name__ == '__main__':
app.run(host='0.0.0.0', port=8889)
小編用的開發(fā)工具是Pycharm,我們運(yùn)行這個(gè)腳本會(huì)彈出以下的結(jié)果。
然后在瀏覽器當(dāng)中輸入彈出來(lái)的url去訪問(wèn)頁(yè)面,如下所示就會(huì)出現(xiàn)含有“hello world”的頁(yè)面。
從代碼的邏輯中來(lái)看,app = Flask(__name__)是創(chuàng)建Flask程序?qū)嵗?,我們?cè)跒g覽器中輸入url發(fā)送請(qǐng)求給web服務(wù)器,然后web服務(wù)器將url轉(zhuǎn)發(fā)給Flask程序?qū)嵗?,因此需要知道?duì)于每一個(gè)url請(qǐng)求需要啟動(dòng)哪一部分的代碼,所以保存了url和Python函數(shù)之間的映射關(guān)系,處理上述兩者之間關(guān)系的是路由,是使用程序?qū)嵗齛pp.route裝飾器來(lái)實(shí)現(xiàn)。而執(zhí)行最后的app.run()就可以啟動(dòng)服務(wù)了,0.0.0.0表示監(jiān)聽所有地址,指定的端口號(hào)是8889,那么我們來(lái)看一下相對(duì)應(yīng)的FastAPI版本的“HelloWorld”是什么樣子的,代碼如下:
from fastapi import FastAPI
from fastapi.responses import PlainTextResponse, HTMLResponse, FileResponse
import uvicorn
app = FastAPI()
@app.get("/", response_class=PlainTextResponse)
async def hello(): ## async可加可不加,這個(gè)隨意
return "Hello World!"
@app.get("/items/{item_id}")
def read_item(item_id: int, q: str = None):
return {"item_id": item_id, "q": q}
if __name__ == '__main__':
uvicorn.run('fast_api_1:app', host='0.0.0.0', port=8000)
我們同樣來(lái)運(yùn)行這段代碼,F(xiàn)astAPI默認(rèn)監(jiān)聽的地址是127.0.0.1,端口號(hào)指定是8000,因此我們輸入http://127.0.0.1:8000/,結(jié)果如下所示:
由于返回的是一個(gè)字符串,因此我們?cè)趓esponse_class處填的是PlainTextResponse,同時(shí)我們也可以在瀏覽器中輸入http://127.0.0.1:8000/items/5?q=somequery,出來(lái)的結(jié)果如下所示:
返回隨機(jī)數(shù)
我們?cè)谏厦娴摹癏ello World”的基礎(chǔ)之上再來(lái)寫幾個(gè)案例,例如返回隨機(jī)數(shù)的操作,在Flask框架當(dāng)中的代碼如下:
@app.route('/random-number')
def random_number():
return str(random.randrange(100))我們?cè)跒g覽器中測(cè)試一下出來(lái)的結(jié)果,如下所示:
而在FastAPI框架當(dāng)中的代碼也是非常類似的。
@app.get('/random-number', response_class=PlainTextResponse)
async def random_number():
return str(random.randrange(100))
判斷是否都是由字母組成
接下來(lái)我們來(lái)看一下,當(dāng)我們發(fā)送一個(gè)GET請(qǐng)求,判斷當(dāng)中的一個(gè)url請(qǐng)求參數(shù)是否都是由字母組成的,其中Flask框架當(dāng)中的代碼如下:
@app.route('/alpha', methods=['GET'])
def alpha():
text = request.args.get('text', '')
result = {'text': text, 'is_alpha' : text.isalpha()}
return jsonify(result)我們?cè)跒g覽器中測(cè)試一下出來(lái)的結(jié)果,如下所示:
而在FastAPI框架當(dāng)中相對(duì)應(yīng)的代碼如下:
@app.get('/alpha')
async def alpha(text: str):
result = {'text': text, 'is_alpha' : text.isalpha()}
return result
創(chuàng)建新用戶
上面的幾個(gè)案例都是GET請(qǐng)求,下面我們來(lái)看一下POST請(qǐng)求該如何處理,例如我們想通過(guò)POST請(qǐng)求來(lái)創(chuàng)建一個(gè)新用戶,在Flask框架中的代碼如下:
@app.route('/create-user', methods=['POST'])
def create_user():
id = request.form.get('id', '0001')
name = request.form.get('name', 'Anonymous')
data = {'id': id, 'name': name}
result = {'status_code': '0', 'status_message' : 'Success', 'data': data}
return jsonify(result)可以直接在Postman當(dāng)中測(cè)試一下該API的功能,如下所示:
我們需要在“methods”當(dāng)中指定是用POST請(qǐng)求,而在FastAPI框架當(dāng)中則不需要指定,直接只用app.post()裝飾器即可:
@app.post('/create-user')
async def create_user(id: str = Form(...), name: str = Form(...)):
data = {'id': id, 'name': name}
result = {'status_code': '0', 'status_message' : 'Success', 'data': data}
return result
返回靜態(tài)頁(yè)面
而要是碰到需要返回一個(gè)靜態(tài)頁(yè)面的時(shí)候,在Flask框架中的代碼是這樣子的。
@app.route('/get-webpage', methods=['GET'])
def get_webpage():
return render_template('flask_1.html', message="Contact Us")而在FastAPI框架當(dāng)中則稍微有些麻煩,代碼如下:
app.mount("/static", StaticFiles(directory="static"), name="static")
## 用來(lái)加載靜態(tài)頁(yè)面
templates = Jinja2Templates(directory="templates")
@app.get('/get-webpage', response_class=HTMLResponse)
async def get_webpage(request: Request):
return templates.TemplateResponse("index.html", {"request": request, "message": "Contact Us"})由于返回的是靜態(tài)頁(yè)面,因此response_class相對(duì)應(yīng)的是HTMLResponse
總結(jié)
我們將上面所寫的Flask代碼全部都?xì)w總一下,如下所示:
from flask import Flask, request, render_template
import random
from flask import jsonify
import json
app = Flask(__name__)
@app.route('/')
def hello_world():
return 'hello world'
@app.route('/random-number')
def random_number():
return str(random.randrange(100))
@app.route('/alpha', methods=['GET'])
def alpha():
text = request.args.get('text', '')
result = {'text': text, 'is_alpha' : text.isalpha()}
return jsonify(result)
@app.route('/create-user', methods=['POST'])
def create_user():
id = request.form.get('id', '0001')
name = request.form.get('name', 'Anonymous')
data = {'id': id, 'name': name}
result = {'status_code': '0', 'status_message' : 'Success', 'data': data}
return jsonify(result)
@app.route('/get-webpage', methods=['GET'])
def get_webpage():
return render_template('flask_1.html', message="Contact Us")
if __name__ == '__main__':
app.run(host='0.0.0.0', port=8889)
而將所有的FastAPI框架下的代碼全部匯總到一起,則如下所示:
from fastapi import FastAPI, Request, Form
import uvicorn
from fastapi.staticfiles import StaticFiles
from fastapi.responses import PlainTextResponse, HTMLResponse, FileResponse
import random
from fastapi.templating import Jinja2Templates
app = FastAPI()
app.mount("/templates", StaticFiles(directory="templates"), name="templates")
templates = Jinja2Templates(directory="templates")
@app.get("/", response_class=PlainTextResponse)
async def hello():
return "Hello World!"
@app.get("/items/{item_id}")
def read_item(item_id: int, q: str = None):
return {"item_id": item_id, "q": q}
@app.get('/random-number', response_class=PlainTextResponse)
async def random_number():
return str(random.randrange(100))
@app.get('/get-webpage', response_class=HTMLResponse)
async def get_webpage(request: Request):
return templates.TemplateResponse("index.html", {"request": request, "message": "Contact Us"})
if __name__ == '__main__':
uvicorn.run('fast_api_1:app', host='0.0.0.0', port=8000)
網(wǎng)頁(yè)名稱:手把手教你入門Python中的Web開發(fā)框架
本文網(wǎng)址:http://m.fisionsoft.com.cn/article/dhhjpih.html


咨詢
建站咨詢
