0

0

如何使用 Flask 和 Python 创建 RESTful API

聖光之護

聖光之護

发布时间:2024-10-16 16:16:43

|

1180人浏览过

|

来源于dev.to

转载

如何使用 flask 和 python 创建 restful api

restful api 在现代开发中至关重要,它允许不同的系统以高效且可扩展的方式进行通信。 python 及其 flask 框架提供了一种简单而强大的方法来创建 api。在本指南中,我们将探索如何使用 flask 创建 restful api,涵盖从基础知识到 http 客户端的身份验证和使用的所有内容。

什么是 restful api?

在开始编写代码之前,了解什么是 restful api 非常重要。 api(应用程序编程接口)是一组允许一个软件与另一个软件通信的规则。 rest(表述性状态传输) 样式定义了 api 必须遵循的一组原则:

  • 客户端-服务器:客户端(使用api​​)和服务器(提供数据)之间的分离。
  • 无状态:客户端发出的每个请求都必须包含服务器处理所需的所有信息。
  • 可缓存:可以缓存 api 响应以提高性能。
  • 统一接口:客户端和服务器之间的通信必须以标准化的方式进行,使用http方法,例如get、post、put和delete。

使用 flask 创建 restful api

现在我们将创建一个简单的 api 来管理用户列表。该 api 将允许您添加、编辑、查看和删除用户。

1.安装flask

首先,确保你已经安装了 flask。如果没有,您可以使用 pip 安装:

pip install flask

2. 项目结构

我们的项目将具有以下结构:

/api_flask
│
├── app.py
└── requirements.txt

3. 配置 flask

在 app.py 文件中,我们首先导入必要的库并配置我们的 flask 应用程序:

from flask import flask, jsonify, request

app = flask(__name__)

# dados simulados
users = [
    {'id': 1, 'name': 'alice', 'email': 'alice@example.com'},
    {'id': 2, 'name': 'bob', 'email': 'bob@example.com'}
]

4. 创建端点

现在,让我们为查看添加更新删除用户创建端点。

立即学习Python免费学习笔记(深入)”;

4.1.列出用户的端点

我们将使用get方法列出所有用户:

@app.route('/users', methods=['get'])
def get_users():
    return jsonify(users), 200

4.2.获取特定用户的端点

我们将使用 get 方法和用户 id 来获取特定用户的详细信息:

@app.route('/users/', methods=['get'])
def get_user(user_id):
    user = next((user for user in users if user['id'] == user_id), none)
    if user:
        return jsonify(user), 200
    else:
        return jsonify({'message': 'user not found'}), 404

4.3.创建新用户的端点

post 方法将用于添加新用户。客户端将以 json 格式发送数据。

@app.route('/users', methods=['post'])
def create_user():
    data = request.get_json()
    new_user = {
        'id': len(users) + 1,
        'name': data['name'],
        'email': data['email']
    }
    users.append(new_user)
    return jsonify(new_user), 201

4.4.更新用户的端点

这里我们使用put方法来更新现有用户的数据:

如家快捷酒店预订网站源码
如家快捷酒店预订网站源码

本源码是采用住哪API程序、连锁酒店单品牌版本,只有如家酒店单品牌预订功能,代码更简练,维护更容易,更适用于地方站长用于做品牌类酒店预订的站长们,占用空间不到100M,也就是说只要你有空间,支持asp和access,那么你就可以拥有一个品牌类酒店预订的网站。 本程序安装目录不限,可以是根目录也可以是二级目录,本程序无需建站经验,功能强大、极易上手,没有网站的朋友可以使用该程序建立功能强大还可创收

下载
@app.route('/users/', methods=['put'])
def update_user(user_id):
    data = request.get_json()
    user = next((user for user in users if user['id'] == user_id), none)
    if user:
        user['name'] = data['name']
        user['email'] = data['email']
        return jsonify(user), 200
    else:
        return jsonify({'message': 'user not found'}), 404

4.5.删除用户的端点

我们使用delete方法来删除用户:

@app.route('/users/', methods=['delete'])
def delete_user(user_id):
    global users
    users = [user for user in users if user['id'] != user_id]
    return jsonify({'message': 'user deleted'}), 200

5. 运行api

现在,只需运行我们的应用程序:

if __name__ == '__main__':
    app.run(debug=true)

运行app.py文件,我们的api将在http://127.0.0.1:5000/users可用。

6. 使用 flask 进行身份验证

要为我们的 api 添加一层安全性,我们可以使用 jwt(json web 令牌)。使用 jwt,我们可以确保只有经过身份验证的用户才能访问某些端点。

6.1.安装 flask-jwt-extend

安装所需的扩展:

pip install flask-jwt-extended

6.2.配置 jwt

更新您的 app.py 文件以包含 jwt 身份验证:

from flask_jwt_extended import jwtmanager, create_access_token, jwt_required

app.config['jwt_secret_key'] = 'your-secret-key'  # troque pela sua chave secreta
jwt = jwtmanager(app)

# login para obter o token
@app.route('/login', methods=['post'])
def login():
    data = request.get_json()
    if data['username'] == 'admin' and data['password'] == 'admin':
        access_token = create_access_token(identity={'username': 'admin'})
        return jsonify(access_token=access_token), 200
    else:
        return jsonify({'message': 'invalid credentials'}), 401

# exemplo de endpoint protegido
@app.route('/protected', methods=['get'])
@jwt_required()
def protected():
    return jsonify({'message': 'access granted to protected endpoint'}), 200

现在,当访问 /protected 端点时,需要在请求标头中发送 jwt 令牌来验证用户身份。

7. 通过 http 客户端使用 api

要使用 api,我们可以使用 postman 等工具或 python 中的 requests 等库。

如何使用请求使用 api 的示例:

import requests

# Consumindo o endpoint de listagem de usuários
response = requests.get('http://127.0.0.1:5000/users')
print(response.json())

结论

使用 flask 创建 restful api 既简单又灵活。 flask 提供了一个简约的框架,可以扩展以包含身份验证、错误处理和其他安全层等功能。通过遵循 rest 原则和良好的开发实践,可以使用 python 构建高效且可扩展的 api。

现在您可以使用 flask 构建自己的 restful api,根据您的需求和要求进行自定义。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

751

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

636

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

758

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

618

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1262

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

577

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

706

2023.08.11

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 3.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号