太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的

有一个非常简单的需求:编写一个 HTTP接口 , 使用 POST 方式发送一个 JSON 字符串 , 接口里面读取发送上来的参数 , 对其中某个参数进行处理 , 并返回 。
如果我们使用 Flask 来开发这个接口 , 那么代码是这样的:
from flask import Flask, requestapp = Flask(__name__)@app.route('/insert', methods=['POST'])def insert():info = request.jsonname = info['name']age = info['age']age_after_10_years = age + 10msg = f'此人名叫:{name} , 10年后 , 此人年龄:{age_after_10_years}'return {'success': True, 'msg': msg}代码看起来已经很简洁了 。 我们用requests发个请求看看效果 , 如下图所示:
太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的文章插图
看起来没什么问题 。
现在 , 我搞点破坏 , 把age字段改成字符串 , 再运行一下:
太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的文章插图
不出所料 , 报错了 。
现在我们把age字段改回数字 , 但是直接移除name字段:
太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的文章插图
【太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的】又报错了 。
为了防止用户不按规矩提交数据 , 我们必须在接口里面做好各种异常数据的判断 。 于是增加判断以后的代码变得复杂了:
@app.route('/insert', methods=['POST'])def insert():info = request.jsonname = info.get('name', '')if not name:return {'success': False, 'msg': 'name 参数不可省略 , 不可为空!'}age = info.get('age', 0)if not isinstance(age, int):return {'success': False, 'msg': 'age参数不是数字!'}age_after_10_years = age + 10msg = f'此人名叫:{name} , 10年后 , 此人年龄:{age_after_10_years}'return {'success': True, 'msg': msg}看来 , 用 Flask , 虽然能让你用很短的代码写出一个能工作的项目 。 但要写成一个可以正常使用的项目 , 还是需要你自己写更多代码 。
下面我们来看一下 , 现代化的 web 框架:FaskApi能把这个工程简化到什么程度:
from fastapi import FastAPIfrom pydantic import BaseModelapp = FastAPI()class People(BaseModel):name: strage: intaddress: strsalary: float@app.post('/insert')def insert(people: People):age_after_10_years = people.age + 10msg = f'此人名字叫做:{people.name} , 十年后此人年龄:{age_after_10_years}'return {'success': True, 'msg': msg}我们还是使用 requests 发一条信息给 FastApi 开发的 HTTP接口 。 对于正常数据 , 正常使用:
太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的文章插图
现在我们把age字段改成字符串:
太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的文章插图
返回友好的提示信息 , 告诉我类型错误:age 字段不是 integer 。
我们再试一试把name字段去掉:
太好用了!别再苦苦用着Flask了,来带你看看它,你会爱上的文章插图
返回友好信息 , 提示值错误:name字段丢失 。
整个过程中 , 对类型的检查全都由 FastApi 自己完成 。 我们省下来很多时间 。
我用了 Flask 四年 , 但在使用了5分钟 FastApi 以后 , 我决定以后不再使用 Flask 了 。
回过头来 , 我们好好介绍一下 FastApi 。