1.通过服务器重写规则,将所有请求走一个入口方法,例如index.php的run()方法。

2.通过$_SERVER,找到请求方法,请求路径,请求参数,进行初始化参数

3.根据请求路径,走不同model处理,根据请求方法不同,走不同的处理方法。

4.补充,可以封装错误和异常处理,提前定义好允许的请求方法,等等。

以下为补充材料

https://blog.csdn.net/lmseo5hy/article/details/83862383

Restful API接口规范包括以下部分:

一、协议

API与用户的通信协议,总是使用HTTPs协议。

二、域名

应该尽量将API部署在专用域名之下,如https://api.oldboyedu.com;如果确定API很简单,不会有进一步扩展,可以考虑放在主域名下,如https://oldboyedu.com/api/。

三、版本

可以将版本号放在HTTP头信息中,也可以放入URL中,如https://api.oldboyedu.com/v1/

四、路径

路径是一种地址,在互联网上表现为网址,在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词,而且所用的名词往往与数据库的表格名对应。一般来说,数据库中的表都是同种记录的"集合"(collection),所以API中的名词也应该使用复数,如https://api.oldboyedu.com/v1/students。

五、HTTP动词

对于资源的具体操作类型,由HTTP动词表示,HTTP动词主要有以下几种,括号中对应的是SQL命令。

1. GET(SELECT):从服务器取出资源(一项或多项);

2. POST(CREATE):在服务器新建一个资源;

3. PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源);

4. PATCH(UPDATE):在服务器更新资源(客户端提供改变的属性);

5. DELETE(DELETE):从服务器删除资源;

6. HEAD:获取资源的元数据;

7. OPTIONS:获取信息,关于资源的哪些属性是客户端可以改变的。

六、过滤信息

如果记录数量很多,服务器不可能都将它们返回给用户,API会提供参数,过滤返回结果,常见的参数有:

1. ?limit=20:指定返回记录的数量为20;

2. ?offset=8:指定返回记录的开始位置为8;

3. ?page=1&per_page=50:指定第1页,以及每页的记录数为50;

4. ?sortby=name&order=asc:指定返回结果按照name属性进行升序排序;

5. ?animal_type_id=2:指定筛选条件。

七、状态码

服务器会向用户返回状态码和提示信息,以下是常用的一些状态码:

1. 200 OK - [GET]:服务器成功返回用户请求的数据;

2. 201 CREATED - [POST/PUT/PATCH]:用户新建或修改数据成功;

3. 202 Accepted - [*]:表示一个请求已经进入后台排队(异步任务);

4. 204 NO CONTENT - [DELETE]:用户删除数据成功;

5. 400 INVALID REQUEST - [POST/PUT/PATCH]:用户发出的请求有错误,服务器没有进行新建或修改数据的操作;

6. 401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误);

7. 403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的;

8. 404 NOT FOUND - [*]:用户发出的请求针对的是不存在的记录,服务器没有进行操作;

9. 406 Not Acceptable - [GET]:用户请求的格式不可得;

10. 410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的;

11. 422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误;

12. 500 INTERNAL SERVER ERROR - [*]:服务器发生错误,用户将无法判断发出的请求是否成功。

八、错误处理

如果状态码是4xx,就会向用户返回出错信息,一般来说,返回的信息中将error作为键名,出错信息作为键值。

九、返回结果

针对不同操作,服务器向用户返回的结果应该符合以下规范:

1. GET /collection:返回资源对象的列表(数组);

2. GET /collection/resource:返回单个资源对象;

3. POST /collection:返回新生成的资源对象;

4. PUT /collection/resource:返回完整的资源对象;

5. PATCH /collection/resource:返回完整的资源对象;

6. DELETE /collection/resource:返回一个空文档。

十、Hypermedia API

RESTful API最好做到Hypermedia,即返回结果中提供链接,连向其他API方法,使得用户不查文档,也知道下一步应该做什么。

以上是Restful API设计应遵循的十大规范,除此之外,Restful API还需注意身份认证应该使用OAuth 2.0框架,服务器返回的数据格式,应该尽量使用JSON,避免使用XML。
————————————————
版权声明:本文为CSDN博主「lmseo5hy」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/lmseo5hy/article/details/83862383

Restful API思路相关推荐

  1. Restful API的设计思路

    API的就是程序员的UI,和其他UI一样,你必须仔细考虑它的用户体验! Restful只是web api/Json传输接口通过http调,取到还要自己解.Rpc一般都是配套的,客户端直接像调本地函数一 ...

  2. Swagger 生成 PHP restful API 接口文档

    需求和背景 需求: 为客户端同事写接口文档的各位后端同学,已经在各种场合回忆了使用自动化文档工具前手写文档的血泪史. 我的故事却又不同,因为首先来说,我在公司是 Android 组负责人,属于上述血泪 ...

  3. 用python写通用restful api service(一)

    一直在用node.js做后端,要逐步涉猎大数据范围,注定绕不过python,因此决定把一些成熟的东西用python来重写,一是开拓思路.通过比较来深入学习python:二是有目标,有动力,希望能持之以 ...

  4. RESTful API浅谈

    解释 API,应用程序接口,也可以叫应用程序界面,或者简称为应用接口.应用程序的设计可以相当复杂,但最终的用户并不需要知道应用程序的内部到底是如何工作的,你只需要给用户提供一些操作接口,再告诉用户怎么 ...

  5. 人人都是 API 设计者:我对 RESTful API、GraphQL、RPC API 的思考

    有一段时间没怎么写文章了,今天提笔写一篇自己对 API 设计的思考.首先,为什么写这个话题呢?其一,我阅读了<阿里研究员谷朴:API 设计最佳实践的思考>一文后受益良多,前两天并转载了这篇 ...

  6. larvel 中的api.php_Laravel API 系列教程(一): 基于 Laravel 5.5 构建 测试 RESTful API...

    Laravel API 系列教程(一): 基于 Laravel 5.5 构建 & 测试 RESTful API 由 学院君 创建于2年前, 最后更新于 9个月前 版本号 #3 171702 v ...

  7. SpringMVC Restful api接口实现

    [前言] 面向资源的 Restful 风格的 api 接口本着简洁,资源,便于扩展,便于理解等等各项优势,在如今的系统服务中越来越受欢迎. .net平台有WebAPi项目是专门用来实现Restful ...

  8. 二十八、Node.js中的RESTful API和接口设计

    @Author:Runsen @Date:2020/6/9 人生最重要的不是所站的位置,而是内心所朝的方向.只要我在每篇博文中写得自己体会,修炼身心:在每天的不断重复学习中,耐住寂寞,练就真功,不畏艰 ...

  9. RESTful API 编写规范

    基于一些不错的RESTful开发组件,可以快速的开发出不错的RESTful API,但如果不了解开发规范的.健壮的RESTful API的基本面,即便优秀的RESTful开发组件摆在面前,也无法很好的 ...

最新文章

  1. CVPR2021评审出来了!你的论文怎么样
  2. mysql数据库导出后乱码问题_MySQL导入导出数据出现乱码的解决办法
  3. ASP.NET完整打包卸载更新攻略(By Installshield 2010)【转】
  4. linux获取主板温度电压_自学修电脑:常见主板报警声解析!
  5. C#如何获得系统时间
  6. Maven仓库搭建(二):GitHub、又拍云、七牛云存储
  7. 埃森哲杯第十六届上海大学程序设计联赛春季赛暨上海高校金马五校赛 C序列变换...
  8. java map集合 事务控制_对象回收过程?线程池执行过程? map原理?集合类关系?synchronized 和 volatile ? 同一个类的方法事务传播控制还有作用吗?java 锁...
  9. 现代软件工程系列 学生的精彩文章 (4) 为用户服务
  10. html怎么制作附页,HTML和CSS属性的正确书写规范
  11. 对计算机组装和维护课的总结,计算机组装与维护教师工作总结
  12. 使用NodeJS将文件或图像上传到服务器
  13. Linux输入子系统浅析
  14. WinCE6.0+ S3C6410 IIC驱动源码学习
  15. 山上有一口缸可以装50升水,现在有15升水。老和尚叫小和尚下山挑水,每次可以挑5升。问:小和尚要挑几次水才可以把水缸挑满?通过编程解决这个问题。
  16. MySQL5.5 的安装与配置
  17. 小学信息技术 用计算机画画 教学目标,三年级下册信息技术教学计划4篇
  18. 游戏团队,各职位人员离职所带来的影响和不同
  19. Kubernetes API Aggregation在 Master 的 API Server 中启用 API 聚合功能注册自定义 APIService 资源实现和部署自定义的 API Serv
  20. 秃顶和程序员有直接关系?

热门文章

  1. HTML5制作3D圣诞树效果
  2. 中国微电机行业需求规模与竞争格局研究报告2022版
  3. 《简·爱》《艺妓回忆录》《离家五百里》
  4. python xlwt生成excel,列数大于256,分表
  5. 右键新建excel文档无法打开,提示“文件格式或扩展名无效”
  6. mooc数据结构与算法python版期末测验_中国大学MOOC(慕课)_数据结构与算法Python版_测试题及答案...
  7. Linux adduser
  8. Rossenblatt感知器算法对鸢尾花进行分类
  9. mac版idea插件安装位置
  10. 解决安装Ubuntu找不到按钮