有一个非常简单的需求:编写一个 HTTP 接口,使用 POST 方式发送一个 JSON 字符串,接口里面读取发送上来的参数,对其中某个参数进行处理,并返回。
如果我们使用 Flask 来开发这个接口,那么代码是这样的:
代码看起来已经很简洁了。我们用requests
发个请求看看效果,如下图所示:
看起来没什么问题。
现在,我搞点破坏,把age
字段改成字符串,再运行一下:
不出所料,报错了。
现在我们把age
字段改回数字,但是直接移除name
字段:
又报错了。
为了防止用户不按规矩提交数据,我们必须在接口里面做好各种异常数据的判断。于是增加判断以后的代码变得复杂了:
看来,用 Flask,虽然能让你用很短的代码写出一个能工作的项目。但要写成一个可以正常使用的项目,还是需要你自己写更多代码。
下面我们来看一下,现代化的 web 框架:FastApi
能把这个工程简化到什么程度:
我们还是使用 requests 发一条信息给 FastApi 开发的 HTTP 接口。对于正常数据,正常使用:
现在我们把age
字段改成字符串:
返回友好的提示信息,告诉我类型错误:age 字段不是 integer
。
我们再试一试把name
字段去掉:
返回友好信息,提示值错误:name字段丢失
。
整个过程中,对类型的检查全都由 FastApi 自己完成。我们省下来很多时间。
我用了 Flask 四年,但在使用了 5 分钟 FastApi 以后,我决定以后不再使用 Flask 了。
回过头来,我们好好介绍一下 FastApi。
使用pip
或者pipenv
即可安装 FastApi:
安装完成以后,我们来完成第一个 API:
这里的写法跟 Flask 几乎一致。只不过在 Flask 中,我们定义路由的装饰器为@app.route('/')
。而这里写为@app.get('/')
写好代码以后,我们需要使用uvicorn
来运行 FastApi。首先使用pip
或者pipenv
安装uvicorn
:
然后执行命令:
其中main
表示我们的代码文件为main.py
,app
表示我们初始化的 FastApi 对象的名字。--reload
参数表示在修改了代码以后立即生效,不需要重启。
运行命令以后,我们访问http://127.0.0.1:8000
可以看到接口已经正确返回了 JSON 格式的数据:
那么如何定义一个带参数的 GET 方法呢?我们再写一段代码:
写好代码以后,我们直接在浏览器里面访问新的地址,可以看到修改已经生效了,如下图所示:
如果想限定 uid 只能是数字,不能是字符串怎么办呢?你只需要多加 4 个字符
:
对函数query
的参数使用类型标注,标注为 int 类型。现在我们再来访问一下接口:
当 query 后面的参数不是整数时,正常报错了。
我们再来看一下本文一开始的 POST 方法。在使用 Flask 的时候,我们需要手动验证用户 POST 提交上来的数据是什么格式的,字段对不对。
但使用 FastApi 的时候,我们只需要类型标注就能解决所有问题。首先我们导入from pydantic import BaseModel
,然后继承BaseModel
实现我们允许 POST 方法提交上来的数据字段和格式:
People
这个类通过类型标注,指定了它里面的 4 个字段和他们的类型。现在,我们来实现 POST 方法:
insert
函数的参数people
通过类型标注指定为People
类型。
当我们使用 POST 方式提交数据时,FastApi 自动会以People
中定义的字段为基准来校验数据,发现不对就返回报错信息。
除了开发接口变得非常简单外,FastApi 还会自动帮我们生成接口文档。大家访问http://127.0.0.1:8000/docs
,可以看到接口文档已经自动生成好了:
这个接口不仅能看,而且直接就能在接口页面修改样例数据,发送请求,现场测试:
以上是对 FastApi 的极简介绍。有兴趣的同学可以查阅它的官方文档。
最后,告诉大家,FastApi 是一个异步 Web 框架,它的速度非常非常非常快。远远超过 Flask。
FastApi 是最快的几个 Web 框架之一。速度可以匹敌 Golang 写的接口。详细的对比可以看:https://www.techempower.com/benchmarks/#section=test&runid=7464e520-0dc2-473d-bd34-dbdfd7e85911&hw=ph&test=query&l=zijzen-7
618当当福利:
冲鸭!羊毛薅起来!当当618专享不到4折,Python书籍囤起来!
618来袭,虽然Python的电子书很多,但是经典的Python书籍还是要看纸质的书,感觉这样才有踏实感,而且长时间眼睛阅读也会舒服一些。我推荐几本非常不错的Python书单,都是居家旅行必备的书籍。
Python修炼必读:
-
Python高级编程
-
Python Cookbook
-
流畅的Python
-
Python基础教程
-
精通正则表达式
内功修炼:
代码大全,重构,CleanCode 这些经典的书籍必须要收藏先!
一起来薅当当的羊毛吧
全场自营图书每满100减50元 、满200元减100元
在当当APP或者小程序结算时输入优惠码
优惠码 (VZGVZE) 满150再减30元
花120元买300的书
优惠码有效期:6.9-6.20
优惠码数量有限,先到先得哦
本篇文章来源于: 菜鸟学Python
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python中的elasticsearch是什么?10/14
- ♥ 整理python web框架01/03
- ♥ python如何访问字典09/23
- ♥ 如何在linux中升级python版本09/26
- ♥ 如何终止python中的线程08/26
- ♥ Python线程进阶篇|多线程下载网页03/02
内容反馈