当前位置:网站首页>绝了,这套RESTful API接口设计总结
绝了,这套RESTful API接口设计总结
2022-08-09 10:36:00 【华为云】
作者:知识浅谈,CSDN签约讲师,CSDN博客专家,华为云云享专家,阿里云星级博主
擅长领域:全栈工程师、爬虫、ACM算法
公众号:知识浅谈
联系方式vx:zsqtcc
RESTful API接口设计总结
- RESTfu是一种网络应用程序的设计风格和开发方式,基于HTTP,可以使用XML格式定义或JSON格式定义。
- RESTful适用于移动互联网厂商作为业务接口的场景,实现第三方OTT调用移动网络资源的功能,动作类型为新增、变更、删除所调用资源。
Restful接口使用
基于HTTP协议URL对外暴露
- 标准格式
- http(s): //域名:端口[/版本]/资源1[/子资源2/…/子资源n][/路径变量]
- 多版本控制
- GET http(s): //域名:端口/v1.1/blog/article/10
- 数据查询采用复数
- GET http(s): //域名:端口/v1.1/blog/articles?categoryId=10
- 反面典型
- GET http(s): //域名:端口/v1.1/blog/articles?categoryId=10
使用XML或JSON格式定义
要使用这种类型的返回数据。
GET http(s)://edu.lagou.com/employee/10{ "code":"0", "message":"success", "data":{ "name":"张三", "age":36 }}不要使用带标签的如<div>name:“小王”</div> 这种带有标签的。
不同的行为使用不同的请求方式

Restful接口设计规则
接口保证幂等性
幂等性:当多次重复请求时,接口能够保证与预期相符的结果
例如:我们设计了一个为员工涨薪的接口,本次请求发送后为1号员工涨薪500元。
幂等性的设计方法:
- 前端传递token,存储在redis使用token的唯一性。
- Redis的Setnx方法,防止幂等性问题。
- 使用版本号{乐观锁}解决幂等性问题
- 使用主键的唯一性约束
标准化响应的结果集
- 在标准化的响应结构中要包含code、message两项,分别对应了服务器处理结果与返回的消息内容,除此以外data属性是可选项,包含从响应返回的额外数据,如查询结果、新增或更新后的数据。
- 在语义层面,也要遵循相同的规则例如当服务器处理成功,code固定等于0,如果遇到异常情况,公司内部也要遵循统一的code命名标准例如:code以1XX开头代表参数异常,2XX开头代表数据库处理异常。当然不同的公司有不同的命名规则,一定要提前定义好并严格要求开发团队严格按语义使用编码。
接口无状态设计
这个指的是不要在单个服务器节点上存储用户的状态信息,分布式系统中可能会出现状态不同步,所以要接口无状态。
错误例子:只有单个服务节点保存了会话状态,是不好的。
解决方案:
第 1 种: 客户端存储认证数据
第 2 种 :后台统一存储状态数据
总结
以上就是关于Restful的使用方法与使用规则。
边栏推荐
- 自启服务mock联调跨域问题
- numpy库中的函数 bincount() where() diag() all()
- Transformer+Embedding+Self-Attention原理详解
- 强化学习 (Reinforcement Learning)
- unix系统编程 第十五章 15.2管道
- 阿里神作!吃透这份资料入厂率高达99%
- pytorch widedeep文档
- 【原创】JPA中@PrePersist和@PreUpdate的用法
- [Error record] Solve the problem that ASRock J3455-ITX cannot be turned on without a monitor plugged in
- jvm-类加载系统
猜你喜欢

第二周作业

【 original 】 VMware Workstation implementation Openwrt soft routing, the ESXI, content is very detailed!

【报错记录】解决华擎J3455-ITX不插显示器无法开机的问题

2022强网杯WP

深度学习--循环神经网络(Recurrent Neural Network)

开源SPL,WebService/Restful广泛应用于程序间通讯,如微服务、数据交换、公共或私有的数据服务等。

自启服务mock联调跨域问题

Nodejs服务端

Solve the ali cloud oss - the original 】 【 exe double-click response can't open, to provide a solution

多行省略和选择器
随机推荐
Attentional Feature Fusion
antd表单
How to quickly get through the mirror release process?
【原创】解决阿里云oss-browser.exe双击没反应打不开,提供一种解决方案
多行省略和选择器
xmms的均衡器试验成功 音效相当不错 比rockbox可能还要好
深度学习--循环神经网络(Recurrent Neural Network)
unix环境编程 第十五章 15.9 共享存储
[相机配置] 海康相机丢包配置环境
Demand side power load forecasting (Matlab code implementation)
Qt 国际化翻译
numpy的ndarray取数操作
上传张最近做的E2用的xmms的界面的截图
LM小型可编程控制器软件(基于CoDeSys)笔记二十六:plc的数据存储区(模拟量输入通道部分)
Oracle数据库:for update 和for update nowait的区别
Unix Environment Programming Chapter 15 15.9 Shared Storage
在webgis中显示矢量化后的风险防控信息
json库的dumps()方法和loads()方法
相关系数计算,热力图绘制,代码实现
【 original 】 VMware Workstation implementation Openwrt soft routing, the ESXI, content is very detailed!