使用Python和Flask构建简单的RESTful API

简介: 【10月更文挑战第12天】使用Python和Flask构建简单的RESTful API

使用Python和Flask构建简单的RESTful API

引言

在当今的数字化时代,构建RESTful API已成为开发现代Web应用和服务的重要部分。REST(Representational State Transfer)是一种基于HTTP的网络应用架构风格,使得Web服务变得轻量级、易于理解和使用。本文将介绍如何使用Python和Flask框架,从零开始构建一个简单的RESTful API。

环境准备

在开始之前,请确保你的系统上已经安装了以下工具和库:

  1. Python(建议使用Python 3.x版本)
  2. pip(Python的包管理工具)
  3. 虚拟环境(如venvconda

你可以通过以下命令检查是否已安装Python和pip:

python --version
pip --version

创建虚拟环境

为了隔离项目依赖,建议创建一个虚拟环境:

# 使用 venv 创建虚拟环境
python -m venv venv

# 激活虚拟环境(Windows)
venv\Scripts\activate

# 激活虚拟环境(macOS/Linux)
source venv/bin/activate

安装Flask

在虚拟环境中安装Flask:

pip install Flask

构建RESTful API

接下来,我们将逐步创建一个简单的RESTful API,它允许用户管理“任务”(tasks)。

  1. 创建项目结构

    flask_api/
    ├── app.py
    ├── tasks.py
    └── requirements.txt
    

    requirements.txt文件中添加Flask:

    Flask==2.0.1
    
  2. 编写app.py

    app.py文件将作为我们的主应用程序文件。它初始化Flask应用,并定义路由和视图函数。

    from flask import Flask, jsonify, request, abort
    from tasks import TaskList
    
    app = Flask(__name__)
    
    # 初始化任务列表
    tasks = TaskList()
    
    # 获取所有任务
    @app.route('/tasks', methods=['GET'])
    def get_tasks():
        return jsonify([task.to_dict() for task in tasks.tasks]), 200
    
    # 创建新任务
    @app.route('/tasks', methods=['POST'])
    def create_task():
        if not request.json or not 'title' in request.json:
            abort(400)
        task = tasks.add_task(request.json['title'])
        return jsonify(task.to_dict()), 201
    
    # 获取特定任务
    @app.route('/tasks/<int:task_id>', methods=['GET'])
    def get_task(task_id):
        task = tasks.find_by_id(task_id)
        if task is None:
            abort(404)
        return jsonify(task.to_dict()), 200
    
    # 更新特定任务
    @app.route('/tasks/<int:task_id>', methods=['PUT'])
    def update_task(task_id):
        if not request.json:
            abort(400)
        task = tasks.find_by_id(task_id)
        if task is None:
            abort(404)
        task.title = request.json.get('title', task.title)
        return jsonify(task.to_dict()), 200
    
    # 删除特定任务
    @app.route('/tasks/<int:task_id>', methods=['DELETE'])
    def delete_task(task_id):
        task = tasks.delete_by_id(task_id)
        if task is None:
            abort(404)
        return jsonify({
         'result': True}), 200
    
    if __name__ == '__main__':
        app.run(debug=True)
    
  3. 编写tasks.py

    tasks.py文件将管理任务列表的逻辑。

    class Task:
        def __init__(self, title, task_id=None):
            self.id = task_id
            self.title = title
    
        def to_dict(self):
            return {
         "id": self.id, "title": self.title}
    
    class TaskList:
        def __init__(self):
            self.tasks = []
            self.current_id = 1
    
        def add_task(self, title):
            task = Task(title, self.current_id)
            self.tasks.append(task)
            self.current_id += 1
            return task
    
        def find_by_id(self, task_id):
            for task in self.tasks:
                if task.id == task_id:
                    return task
            return None
    
        def delete_by_id(self, task_id):
            task = self.find_by_id(task_id)
            if task:
                self.tasks.remove(task)
                return task
            return None
    

运行应用

在项目根目录下运行以下命令启动Flask应用:

python app.py

你应该会在控制台看到如下输出,表明应用正在运行:

 * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
 * Restarting with stat
 * Debugger is active!
 * Debugger PIN: 123-456-789

现在,你可以使用API客户端(如Postman或curl)与你的RESTful API进行交互。例如,创建一个新任务:

curl -X POST -H "Content-Type: application/json" -d '{"title": "Buy groceries"}' http://127.0.0.1:5000/tasks

结论

本文介绍了如何使用Python和Flask框架构建一个简单的RESTful API。我们定义了一些基本的CRUD操作来管理任务,并通过Flask的路由和视图函数将这些操作暴露为HTTP端点。希望这个示例能帮助你理解RESTful API的基本构建过程,并激发你进一步探索和实践的兴趣。

目录
相关文章
|
5月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
5月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
5月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
1152 1
Python API接口实战指南:从入门到精通
|
6月前
|
JSON API 数据安全/隐私保护
Python采集淘宝评论API接口及JSON数据返回全流程指南
Python采集淘宝评论API接口及JSON数据返回全流程指南
|
6月前
|
缓存 监控 供应链
唯品会自定义 API 自定义操作深度分析及 Python 实现
唯品会开放平台提供丰富API,支持商品查询、订单管理、促销活动等电商全流程操作。基于OAuth 2.0认证机制,具备安全稳定的特点。通过组合调用基础接口,可实现数据聚合、流程自动化、监控预警及跨平台集成,广泛应用于供应链管理、数据分析和智能采购等领域。结合Python实现方案,可高效完成商品搜索、订单分析、库存监控等功能,提升电商运营效率。
|
6月前
|
缓存 监控 供应链
京东自定义 API 操作深度分析及 Python 实现
京东开放平台提供丰富API接口,支持商品、订单、库存等电商全链路场景。通过自定义API组合调用,可实现店铺管理、数据分析、竞品监控等功能,提升运营效率。本文详解其架构、Python实现与应用策略。
JSON 监控 API
267 0
|
5月前
|
人工智能 自然语言处理 测试技术
Apipost智能搜索:只需用业务语言描述需求,就能精准定位目标接口,API 搜索的下一代形态!
在大型项目中,API 数量庞大、命名不一,导致“找接口”耗时费力。传统工具依赖关键词搜索,难以应对语义模糊或命名不规范的场景。Apipost AI 智能搜索功能,支持自然语言查询,如“和用户登录有关的接口”,系统可理解语义并精准匹配目标接口。无论是新人上手、模糊查找还是批量定位,都能大幅提升检索效率,降低协作成本。从关键词到语义理解,智能搜索让开发者少花时间找接口,多专注核心开发,真正实现高效协作。
|
5月前
|
缓存 监控 前端开发
顺企网 API 开发实战:搜索 / 详情接口从 0 到 1 落地(附 Elasticsearch 优化 + 错误速查)
企业API开发常陷参数、缓存、错误处理三大坑?本指南拆解顺企网双接口全流程,涵盖搜索优化、签名验证、限流应对,附可复用代码与错误速查表,助你2小时高效搞定开发,提升响应速度与稳定性。

推荐镜像

更多