Flask进阶:构建RESTful API和数据库交互

在初级教程中,我们已经介绍了如何使用Flask构建基础的Web应用。在本篇中级教程中,我们将学习如何用Flask构建RESTful API,以及如何使用Flask-SQLAlchemy进行数据库操作。

一、构建RESTful API

REST(Representational State Transfer)是一种构建Web服务的方法,它利用了HTTP协议中的四种基本操作:GET、POST、PUT和DELETE。在Flask中,我们可以方便地为每种HTTP方法定义路由:

python 复制代码
from flask import Flask, request, jsonify
app = Flask(__name__)

todos = []

@app.route('/todos', methods=['GET'])
def get_todos():
    return jsonify(todos)

@app.route('/todos', methods=['POST'])
def add_todo():
    todos.append(request.json.get('todo', ''))
    return '', 204

@app.route('/todos/<int:index>', methods=['PUT'])
def update_todo(index):
    todos[index] = request.json.get('todo', '')
    return '', 204

@app.route('/todos/<int:index>', methods=['DELETE'])
def delete_todo(index):
    del todos[index]
    return '', 204

二、使用Flask-SQLAlchemy进行数据库操作

Flask-SQLAlchemy是Flask的一个扩展,它提供了SQLAlchemy的所有功能,并为其添加了一些方便的功能,如分页支持等。

首先,你需要安装Flask-SQLAlchemy:

python 复制代码
pip install flask-sqlalchemy

然后,我们可以定义一个模型,并进行数据库操作:

python 复制代码
from flask import Flask
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
db = SQLAlchemy(app)

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50))

@app.route('/')
def index():
    user = User.query.filter_by(name='John').first()
    return 'Hello, {}!'.format(user.name)

在上述代码中,我们首先配置了数据库的URI,然后定义了一个User模型,最后在视图函数中进行了数据库查询。

以上,我们介绍了如何使用Flask构建RESTful API,以及如何使用Flask-SQLAlchemy进行数据库操作。希望这篇文章能帮助你深入理解Flask,开发更复杂的Web应用。

相关推荐
贺国亚3 分钟前
Text-to-SQL与Analytics-Agent
后端
一只叫煤球的猫21 分钟前
ThreadForge 源码解读二:一个 Task 从 submit 到完成,内部到底发生了什么?
java·后端·面试
python-码博士33 分钟前
PyTorch 从零实现 Flow Matching:训练、采样、画图一条龙
人工智能·pytorch·python
苏三说技术34 分钟前
AgentScope Java 2.0 正式发布了!
后端
ping某1 小时前
一个“日志备份”需求,为什么会牵出整个 Linux 日志系统?
后端·架构
王小王-1231 小时前
基于Python的车联网数据聚合与可视化分析平台设计与实现
python·车联网·新能源汽车·车联网聚合分析
血小溅1 小时前
Spring AI 对 Skill/MCP 的支持全景整理
后端
晓杰'1 小时前
从0到1实现Balatro游戏后端(8):Skip Blind与Tag奖励机制设计与实现
后端·websocket·typescript·项目实战·nestjs·状态管理·游戏服务器
叫我:松哥1 小时前
基于Flask框架的校园二手书籍交易平台,注重校园场景的特殊需求,通过学号认证保障用户真实性
后端·python·sqlite·flask·bootstrap
namexingyun2 小时前
开源前端生态如何成为 AI UI 生成的“燃料“:shadcn/ui、Tailwind CSS、Storybook 技术价值全解剖
java·前端·人工智能·python·ui·开源·ai编程