溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Python?Flask?RESTful怎么使用

發(fā)布時(shí)間:2023-03-16 10:24:29 來(lái)源:億速云 閱讀:103 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本篇內(nèi)容介紹了“Python Flask RESTful怎么使用”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

一、RESTful 概述

REST(Representational State Transfer)風(fēng)格是一種面向資源的 Web 應(yīng)用程序設(shè)計(jì)風(fēng)格,它遵循一些設(shè)計(jì)原則,使得 Web 應(yīng)用程序具有良好的可讀性、可擴(kuò)展性和可維護(hù)性。下面我們來(lái)詳細(xì)解釋一下 RESTful 風(fēng)格的各個(gè)方面:

  • 資源標(biāo)識(shí)符:在 RESTful 風(fēng)格中,每個(gè)資源都有一個(gè)唯一的標(biāo)識(shí)符,通常是一個(gè) URL(Uniform Resource Locator)。URL 用于標(biāo)識(shí)資源的位置,使得客戶(hù)端可以使用 HTTP 協(xié)議進(jìn)行訪(fǎng)問(wèn)。例如,一個(gè)簡(jiǎn)單的 URL 可以是:http://example.com/products/123,其中“products”表示資源類(lèi)型,“123”表示資源標(biāo)識(shí)符。

  • 表示層:資源可以以不同的格式表示,例如 JSON,XML,HTML 等??蛻?hù)端可以根據(jù)需要選擇適當(dāng)?shù)谋硎拘问竭M(jìn)行交互。例如,一個(gè) RESTful API 可以返回 JSON 格式的數(shù)據(jù),以便客戶(hù)端可以更容易地解析和處理數(shù)據(jù)。

  • 自描述消息:每個(gè)消息都應(yīng)該包含足夠的信息,以描述如何處理該消息。例如,HTTP 響應(yīng)應(yīng)該包含狀態(tài)碼、響應(yīng)頭和響應(yīng)正文等信息,以便客戶(hù)端可以理解響應(yīng)的含義。

  • 無(wú)狀態(tài)通信RESTful 風(fēng)格的設(shè)計(jì)強(qiáng)調(diào)無(wú)狀態(tài)通信,這意味著每個(gè)請(qǐng)求都應(yīng)該包含所有必要的信息以處理該請(qǐng)求,而不依賴(lài)于先前的請(qǐng)求。這可以使得 Web 應(yīng)用程序更加簡(jiǎn)單和可擴(kuò)展,因?yàn)?a title="服務(wù)器" target="_blank" href="http://kemok4.com/">服務(wù)器不需要保留任何狀態(tài)信息。

  • 統(tǒng)一接口:所有資源應(yīng)該通過(guò)相同的接口來(lái)訪(fǎng)問(wèn)。這意味著客戶(hù)端可以使用相同的 HTTP 方法(如 GETPOST、PUTDELETE 等)來(lái)操作不同類(lèi)型的資源。這使得 API 更加簡(jiǎn)單和一致,并且更容易被其他開(kāi)發(fā)者理解和使用。

總之,RESTful 風(fēng)格的設(shè)計(jì)使得 Web 應(yīng)用程序更加靈活、可擴(kuò)展和易于維護(hù),是一種現(xiàn)代化的 Web 應(yīng)用程序設(shè)計(jì)方式。

二、Python 中的 RESTful

Python 可以用于實(shí)現(xiàn) RESTful 風(fēng)格的 Web 應(yīng)用程序,通常使用一些 Web 框架來(lái)簡(jiǎn)化開(kāi)發(fā)過(guò)程。下面是一些常見(jiàn)的 Python Web 框架:

  • FlaskFlask 是一個(gè)簡(jiǎn)單、輕量級(jí)的 Web 框架,可以用來(lái)構(gòu)建 RESTful 風(fēng)格的 Web 應(yīng)用程序。它使用 Python 的裝飾器語(yǔ)法來(lái)定義 HTTP 路由,使得編寫(xiě) Web 應(yīng)用程序變得簡(jiǎn)單和直觀(guān)。Flask 還提供了擴(kuò)展機(jī)制,使得開(kāi)發(fā)人員可以輕松地添加新的功能,例如數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)、表單驗(yàn)證等。

  • DjangoDjango 是一個(gè)功能強(qiáng)大、全面的 Web 框架,可以用于構(gòu)建復(fù)雜的 Web 應(yīng)用程序。它提供了許多內(nèi)置功能,例如 ORM(對(duì)象關(guān)系映射)、表單驗(yàn)證、身份驗(yàn)證等,可以使開(kāi)發(fā)人員更快地構(gòu)建 Web 應(yīng)用程序。Django 也支持 RESTful 風(fēng)格的 Web 應(yīng)用程序開(kāi)發(fā),可以使用第三方庫(kù) Django REST framework 來(lái)實(shí)現(xiàn)。

  • BottleBottle 是一個(gè)輕量級(jí)的 Web 框架,它使用 Python 的裝飾器語(yǔ)法來(lái)定義 HTTP 路由,可以快速構(gòu)建 RESTful 風(fēng)格的 Web 應(yīng)用程序。Bottle 還包含了一些有用的功能,例如模板引擎、數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)、靜態(tài)文件處理等。

  • PyramidPyramid 是一個(gè)靈活、高度可定制的 Web 框架,可以用于構(gòu)建各種類(lèi)型的 Web 應(yīng)用程序,包括 RESTful 風(fēng)格的 Web 應(yīng)用程序。Pyramid 提供了許多擴(kuò)展機(jī)制,使得開(kāi)發(fā)人員可以輕松地添加新的功能,例如數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)、表單驗(yàn)證、身份驗(yàn)證等。

以上框架都支持 RESTful 風(fēng)格的 Web 應(yīng)用程序開(kāi)發(fā),并且都具有各自的優(yōu)缺點(diǎn),開(kāi)發(fā)人員可以根據(jù)自己的需求選擇合適的框架。

三、Flask RESTful API 示例講解

1)Flask-RESTful 庫(kù)講解

Flask-RESTful 是一個(gè)基于 Flask 的擴(kuò)展庫(kù),它提供了一些方便的工具來(lái)構(gòu)建 RESTful API。下面是 Flask-RESTful 的一些主要特點(diǎn)和功能:

  • 資源類(lèi):Flask-RESTful 提供了一個(gè) Resource 基類(lèi),可以用來(lái)創(chuàng)建資源。Resource 類(lèi)包含了 HTTP 方法(GETPOST、PUT、DELETE 等)的處理邏輯,并提供了一些方便的方法來(lái)處理請(qǐng)求和響應(yīng)。

  • 請(qǐng)求參數(shù)解析:Flask-RESTful 提供了一個(gè) RequestParser 類(lèi),用于解析請(qǐng)求參數(shù)。RequestParser 可以自動(dòng)將查詢(xún)參數(shù)、表單參數(shù)、JSON 參數(shù)等解析成 Python 類(lèi)型,并提供了一些選項(xiàng)來(lái)指定參數(shù)的類(lèi)型、默認(rèn)值、必須存在等限制條件。

  • 響應(yīng)格式化:Flask-RESTful 提供了一個(gè) marshal_with() 裝飾器,用于格式化響應(yīng)數(shù)據(jù)。marshal_with() 裝飾器可以將 Python 對(duì)象轉(zhuǎn)換成指定的輸出格式(如 JSON、XML 等),并支持指定輸出字段、字段類(lèi)型、嵌套字段等功能。

  • 路由定義: Flask-RESTful 提供了一個(gè) Api 類(lèi),用于定義路由和資源的映射關(guān)系。Api 類(lèi)包含了 add_resource()方法,用于將資源類(lèi)和 URL 路由綁定起來(lái)。

  • 異常處理:Flask-RESTful 提供了一些異常類(lèi),用于處理 HTTP 請(qǐng)求和響應(yīng)中的錯(cuò)誤。Flask-RESTful 的異常類(lèi)包括 abort、HTTPException 等,可以方便地處理 HTTP 狀態(tài)碼、錯(cuò)誤信息等。

綜上所述,F(xiàn)lask-RESTful 提供了一些方便的工具來(lái)簡(jiǎn)化 RESTful API 的開(kāi)發(fā)。使用 Flask-RESTful 可以快速地定義資源、解析請(qǐng)求參數(shù)、格式化響應(yīng)數(shù)據(jù)、定義路由和處理異常等,從而提高開(kāi)發(fā)效率并降低出錯(cuò)的風(fēng)險(xiǎn)。

2)Flask-RESTful 庫(kù)安裝

要安裝 Flask-RESTful 庫(kù),可以使用 pip 命令進(jìn)行安裝。在終端中執(zhí)行以下命令:

pip3 install flask-restful

這將會(huì)從 PyPI 上下載 Flask-RESTful 庫(kù),并安裝到本地的 Python 環(huán)境中。安裝完成后,就可以在代碼中導(dǎo)入 flask_restful 模塊,使用 Flask-RESTful 提供的功能來(lái)構(gòu)建 RESTful API。

3)RESTful 示例講解

下面是一個(gè)簡(jiǎn)單的 Flask RESTful API 示例,它實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的 To-Do List 應(yīng)用程序:

from flask import Flask, request
from flask_restful import Api, Resource, reqparse, fields, marshal_with
app = Flask(__name__)
api = Api(app)
todos = {}
todo_fields = {
    'id': fields.Integer,
    'task': fields.String,
    'status': fields.Boolean
}
class TodoList(Resource):
    @marshal_with(todo_fields)
    def get(self):
        return todos
    @marshal_with(todo_fields)
    def post(self):
        parser = reqparse.RequestParser()
        parser.add_argument('task', type=str, help='Task is required', required=True)
        args = parser.parse_args()
        todo_id = len(todos) + 1
        todo = {'task': args['task'], 'status': False}
        todos[todo_id] = todo
        return todo, 201
class TodoItem(Resource):
    @marshal_with(todo_fields)
    def get(self, todo_id):
        return todos[todo_id]
    def put(self, todo_id):
        parser = reqparse.RequestParser()
        parser.add_argument('task', type=str)
        parser.add_argument('status', type=bool)
        args = parser.parse_args()
        todo = todos[todo_id]
        if args['task']:
            todo['task'] = args['task']
        if args['status']:
            todo['status'] = args['status']
        return todo
    def delete(self, todo_id):
        del todos[todo_id]
        return '', 204
api.add_resource(TodoList, '/todos')
api.add_resource(TodoItem, '/todos/<int:todo_id>')
if __name__ == '__main__':
    app.run(debug=True)

啟動(dòng)

# 配置環(huán)境變量
export FLASK_APP=restful-test.py
# 啟動(dòng)服務(wù),公開(kāi)訪(fǎng)問(wèn)需要加上--host=0.0.0.0
python -m flask run --host=0.0.0.0

該示例使用 Flask 和 Flask-RESTful 庫(kù)來(lái)實(shí)現(xiàn) To-Do List 應(yīng)用程序的 RESTful API。下面是一些重要的代碼片段的解釋?zhuān)?/p>

  • 定義資源:在示例中,有兩個(gè)資源:TodoList 和 TodoItemTodoList 用于處理所有的 To-Do 任務(wù)列表,TodoItem 用于處理單個(gè)任務(wù)。

  • 定義請(qǐng)求參數(shù):在示例中,我們使用 Flask-RESTful 庫(kù)的 RequestParser 來(lái)解析請(qǐng)求參數(shù)。我們定義了 'task' 和 'status' 參數(shù),并使用 add_argument() 方法來(lái)指定它們的類(lèi)型和其他限制條件。

  • 定義響應(yīng)格式:在示例中,我們使用 Flask-RESTful 庫(kù)的 marshal_with() 裝飾器來(lái)定義響應(yīng)的格式。我們定義了一個(gè)名為 todo_fields 的字典,其中包含了 To-Do 任務(wù)的 idtask 和 status 字段。

  • 定義請(qǐng)求方法:在示例中,我們使用 Flask-RESTful 庫(kù)的 Resource 類(lèi)來(lái)定義請(qǐng)求方法。我們實(shí)現(xiàn)了 GETPOST、PUT 和 DELETE 方法,用于獲取任務(wù)列表、添加任務(wù)、更新任務(wù)刪除任務(wù)

  • 添加路由:在示例中,我們使用 Flask-RESTful 庫(kù)的 Api 類(lèi)來(lái)添加路由。我們使用 add_resource() 方法來(lái)將 TodoList 和 TodoItem 類(lèi)與相應(yīng)的 URL 路由綁定起來(lái)。

在運(yùn)行該示例后,可以通過(guò)訪(fǎng)問(wèn) URL 來(lái)使用 To-Do List 應(yīng)用程序的 RESTful API。例如,要獲取所有任務(wù)列表,可以使用以下 URL:

# GET http://localhost:5000/todos
curl http://localhost:5000/todos

添加一個(gè)新任務(wù),可以使用以下 URL:

# POST http://localhost:5000/todos
curl -XPOST http://localhost:5000/todos -d 'task=123'
curl -XPOST http://localhost:5000/todos -d '{"task":"456"}'  --header "Content-Type: application/json"

獲取單個(gè)任務(wù),可以使用以下 URL:

# GET http://localhost:5000/todos/1
curl http://localhost:5000/todos/1

更新任務(wù),可以使用以下 URL:

# PUT http://localhost:5000/todos/1
curl -XPUT http://localhost:5000/todos/1 -d '{"task":"test"}'  --header "Content-Type: application/json"
# 查看
curl http://localhost:5000/todos/1

刪除任務(wù),可以使用以下 URL:

# DELETE http://localhost:5000/todos/1
curl -XDELETE http://localhost:5000/todos/1

Python?Flask?RESTful怎么使用

“Python Flask RESTful怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI