网站首页 > 技术文章 正文
小帅b今天想跟你聊聊 RESTful API 这玩意,以及如何使用 Python 快速创建你的 API 给别人调用。
你应该经常去调用过 API ,通过一定的规则就能快速使用别人提供的服务,比如你想要使用人脸身份证比对,就有相应的 API 供你使用:
然后你只要调用这个接口就能快速实现:
返回结果:
这样做的好处就是,我们在后端只需要提供接口,然后前端不管是手机、PC、微信小程序等,都可以通过这个接口实现具体的功能,这样的话前后端就可以做到互不 “干涉”,分离部署都可以。
那么我们如何使用 Python 去实现类似这样的 API 接口,提供服务给别人使用呢?RESTful API 又是个什么鬼?
那么接下来就是:
学习 python 的正确姿势
什么是 RESTful API?
虽然说 API 你可以自己定制,但是总不能写成类似这样的吧:
往往,前后端程序员的矛盾就此产生...
前端:
后端:
所以,写一个友好的 API 还是很重要的,而 RESTful API 就是一种流行且友好的风格,它主要用来约束 API 的写法,让别人使用起来能感到清晰,简洁,一目了然,使用方便。
像这样:
我们定义的 URI 需要清晰易于理解,例如:
https://api.fxxkpython.com/shop/products/list
这样我们一眼就能明白这是请求商品数据列表。
尽量通过 JSON 或者 XML 来传递数据对象和属性。
明确的使用 HTTP 方法(例如,get、post、put和delete)。
无状态,在请求的时候,服务端不存储客户端的上下文状态。
Python 如何创建 RESTful API?
相信你对 Python 的 web 框架有一定的了解:
(来自视频号:学习python的正确姿势)
而今天要给你介绍的是基于 Flask 框架写的轻量级额rest API 框架:FlaskRESTful ,它易于使用,写法和 Flask 类似,你也可以直接在你项目中的 ORM 层中使用它。
接下来一起看看官方提供的例子,简单演示一下它的使用。
导入相应的库,定义类资源,在里面可以使用 http 的 get 、put 方法定义接口,接着通过 api 添加资源即可轻松实现一个 API 接口:
运行起来:
访问:
刚说了,你只要定义好资源类,在里面可以写多个 http 的 get、put、post 等方法,比如这里你可以使用 put 来添加 data 数据到字典中:
在这里可以把请求路径的 todo_id 作为变量,运行起来后你就可以往里相应的 put 数据了:
使用 get 方法获取:
在 add_resource 中,你可以定义多个路由指向同一个类资源中去:
访问:
验证表单数据类型,可以使用 reqparse 定义 type:
这样当用户提交的不是 int 类型会直接返回错误信息:
当你的 API 想要返回一个对象的时候,可能你需要对对象中的参数定义好类型,可以使用 fields 和 marshal_with 进行装饰,像这样:
ok,以上就是 FlaskRESTful 的常用操作,更多参数信息可以到以下链接中查看:
https://flask-restful.readthedocs.io/en/latest/
你也可以试着就我们上次说的 用 Python 开发一个 【个人计划 todolist】 用 FlaskRESTful 改写一下,体会一下区别。
那么我们下回见咯,peace!
记得关注我哦!
猜你喜欢
- 2024-10-12 php 给app 或前端封装api 接口——json格式
- 2024-10-12 前端基础:vue中Axios的封装和API接口的管理
- 2024-10-12 Vue项目中实现用户登录及token验证
- 2024-10-12 前端开发:TypeScript 接口与泛型 接口使用泛型
- 2024-10-12 Java实战系列-前端VUE代码开发及接口流程设计(1)
- 2024-10-12 你还不了解typescript中接口和类型别名的用法区别?本文帮你总结
- 2024-10-12 前端开发:JavaScript API应用程序编程接口
- 2024-10-12 Java 中间的接口还可以这样用,你知道吗?
- 2024-10-12 Web前端接口画中画(Picture-in-Picture)介绍
- 2024-10-12 vue 项目接口管理 vue3接口
你 发表评论:
欢迎- 05-10如何优化数据库和前端之间的交互?
- 05-10前端代码优化小秘籍(前端优化24条建议)
- 05-10VS Code当中的15个神仙插件,值得收藏
- 05-10如何自己开发一个Google浏览器插件?
- 05-10前端流行框架Vue3教程:14. 组件传递Props效验
- 05-10吃了一年的SU,最好用的插件都在这了
- 05-10前端必看!这款神器让网站界面告别千篇一律
- 05-10程序员请收好:10个非常有用的 Visual Studio Code 插件
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)