参考: http://www.ibm.com/developerworks/cn/web/1103_chenyan_restapi/

规划好 资源标示结构 和 URI模式, 是API设计成功的关键

原创文章,转载请注明:http://www.cnblogs.com/ganiks/

  1. 规划资源标识结构和URI模式

    1. 规划基本资源类型

      • 针对一个文档的评论, URI 模式可以设计成如下:/ 文件夹 / [ 文件夹名 ] / 文件 / [ 文件名 ] / 评论 / [ 评论唯一标示 ]
    2. 规划集合资源类型
      • 使用过滤条件

        • / 环境工程系 / 学生 ? 籍贯 = 北京 & 性别 = 女
      • 使用排序
        • ?sortOrder=asc&sortField=age
      • 使用分页
        • / 所有学生 ?page=5&pagesize=50
    3. 一些特殊资源类型
      • 如果我们来定义一个新的集合 ----“我检出的文档”,用创建一个集合资源来对应检出(创建一个文档锁),用删除一个集合资源来对应检入(删除一个文档锁)
      • 在 REST 这个以名词为核心的构架结构中,当你遇到一些动词特性比较强的操作,而又很难用原始资源的增删改查来匹配的时候,不妨换个思路, 通过引入新的逻辑资源集合的方式, 来进行 API 的设计与规划。
  2. 理解和使用内容协商
    1. 使用URL参数进行内容协商

      • http://restapi/news/26?format=xml
      • 使用 URL 参数,简单灵活,但是也由此带来了设计上的随意和不标准;过多的参数会导致 URL 的可读性变差,更有甚者,可能会导致 URL 过长,超出规范,API 请求无法执行
    2. 使用Accept头进行内容协商
      • Accept:application/json,text/html
      • Accept-Charset:utf-8
      • Accept-Encoding:gzip,deflate,sdcn
      • Accept-Language:zh-CN,zh;q=0.8,en-US;q=0.6,en;q=0.4
    3. 使用URI模式进行内容协商
  3. 正确的使用HTTP响应代码
    • 200 OK
    • 201 Created
    • 202 Accepted
    • 204 No Content
    • 301 Moved Permanently
    • 302 Found
    • 304 Not Modified
    • 305
    • 400 Bad Request
    • 401 UnAuthorized
    • 403 Forbidden
    • 404 Not Found
    • 405 Method Not Allowed
    • 500 Internal Server Error
    • 501
    • 502 Bad GateWay
    • 504 GateWay Timeout
    • 505
  4. 使用HTTP头处理缓存
    • 缓存控制

      • Cache-control

        • private
        • no-cache
        • max-age=600
        • must-revalidate
      • Expires
    • 条件请求与电子标签
      • 很多时候,内容可能几个小时甚至几天都不会发生变动
      • HTTP头中返回内容的最后修改时间Last-Modified
      • 根据服务器内容生成电子标签ETag
      • 下次请求的时候会使用If-Modified-Since或者If-None-Match头信息把上次请求到的时间戳或者Etag传给服务器,服务器端进行判断后:
        • 返回给用户最新的内容
        • 返回HTTP304,内容没有变化
  5. 使用HTTP头处理并发
    • 条件请求

      • 在发出修改请求的同时,在HTTP头中使用If-Not-Modified-Since或者If-Match头信息,把获取数据时得到的时间戳或者电子标签传给服务器
      • 服务器通过这个与当前内容比较,可知修改请求是否是针对当前内容提出的。
        • 是,则修改
        • 不是,返回HTTP412(未满足前提条件)
  6. 更好的使用数据冗余和链接元素
    • 为了保证 API 的灵活与效率,我们可以提供一个开关参数,如 includeAircraftDetail=true
    • 我们要展示一个文件夹下面所有的文件,并允许用户察看每个文件都允许哪些人编辑,哪些人下载以及将某文件放入收藏夹。这时候,我们可以考虑将这些可以执行的操作的 API 都用链接元素的方式返回给客户端,这样,开发者无需自己拼接 API 调用的 URL,就可以使用,从而降低代码复杂度。

Restful API 最佳实践 (理论篇)的更多相关文章

  1. 我所理解的Restful API最佳实践

    一直在公司负责API数据接口的开发,期间也遇到了不小的坑,本篇博客算是做一个小小的记录. 1. 不要纠结于无意义的规范    在开始本文之前,我想先说这么一句:RESTful 真的很好,但它只是一种软 ...

  2. 我所认为的RESTful API最佳实践

    我所认为的RESTful API最佳实践 不要纠结于无意义的规范 在开始本文之前,我想先说这么一句:RESTful 真的很好,但它只是一种软件架构风格,过度纠结如何遵守规范只是徒增烦恼,也违背了使用它 ...

  3. REST与RESTFul API最佳实践

    我经常会面试一些做PHP的开发者,让我很奇怪的是,10个人总有8个多不知道什么是REST服务,甚至是没有听说过.但RESTFul API已经是现在互联网里对外开放接口的主流模式,可参考: 豆瓣API  ...

  4. Restful Api 最佳实践

    Web APIs has become an very important topic in the last year. We at M-Way Solutions are working ever ...

  5. RESTFul API最佳实践

    RESTful API最佳实践 RESTful API 概述 基本概念 REST 英文全称:Representational State Transfer,直译为:表现层状态转移.首次是由Roy Th ...

  6. RESTful API 最佳实践(转)

    原文:http://www.ruanyifeng.com/blog/2018/10/restful-api-best-practices.html 阮一峰老师的文章,他的文章把难懂的东西讲的易懂 RE ...

  7. RESTful API 最佳实践----转载阮一峰

    文章地址http://www.ruanyifeng.com/blog/2018/10/restful-api-best-practices.html

  8. 我们必须要知道的RESTful服务最佳实践

    看过很多RESTful相关的文章总结,参齐不齐,结合工作中的使用,非常有必要归纳一下关于RESTful架构方式了,RESTful只是一种架构方式的约束,给出一种约定的标准,完全严格遵守RESTful标 ...

  9. ASP.NET Core Web API 最佳实践指南

    原文地址: ASP.NET-Core-Web-API-Best-Practices-Guide 介绍 当我们编写一个项目的时候,我们的主要目标是使它能如期运行,并尽可能地满足所有用户需求. 但是,你难 ...

随机推荐

  1. 设置DataGridView 显示自己添加编辑的列名,不动态显示数据库本身

    设置DataGridView 显示自己添加编辑的列名,不动态显示数据库本身. 方法: (1)界面操作,把DataGridView控件拖放在窗体中,就看到DataGridView控件的右上角有个小三角, ...

  2. 2)main函数在执行前和执行后有哪些操作

    main函数执行之前,主要就是初始化系统相关资源:      1. 设置栈指针      2. 初始化static静态和global全局变量,即data段的内容      3. 将未初始化部分的全局变 ...

  3. Laravel 5 基础(十一)- 表单验证

    在建立一个文章的时候,如果你什么都不输入直接提交,ok,你获得了一个空的文章,没有任何错误提示,这是不对的.在命令行下运行 php artisan 可以看到一个选项 make:request,新建一个 ...

  4. UltraEdit中使用正则表达式

    正则表达式 (UltraEdit Syntax): % 匹配行首 - 表明要搜索的字符串一定在行首. $ 匹配行尾 - 表明要搜索的字符串一定在行尾 ? 匹配除换行符外的任一单个字符. * 匹配任意个 ...

  5. Java 第六天 Spring Annotation 和其它

    Annotation,是Java语言中的一种特殊的元数据语法,Spring支持使用annotation来进行对象实例化和装配 使用Annotation在Spring的配置xml中添加context命名 ...

  6. virtualenv 安装

    virtualenv 是一个创建隔离的Python环境的工具. virtualenv要解决的根本问题是库的版本和依赖,以及权限问题.假设你有一个程序,需要LibFoo的版本1,而另一个程序需要版本2, ...

  7. Ruby on Rail学习笔记

    说明:只针对Windows8.1 Windows下,上rubyinstaller上下载最新的railsinstaller包含Ruby2.1的,然后更新gem 用命令: gem update --sys ...

  8. 简答的理解C语言中的各种类型函数

    1.变参函数 变长参数的函数即参数个数可变.参数类型不定 的函数.最常见的例子是printf函数.scanf函数和高级语言的Format函数.在C/C++中,为了通知编译器函数的参数个数和类型可变(即 ...

  9. [目录]Pentaho Kettle解决方案:使用PDI构建开源ETL解决方案

    第一部分:开始 1         ETL入门 1.1   OLTP和数据仓库对比 1.2   ETL是什么 1.2.1          ETL解决方案的演化过程 1.2.2          ET ...

  10. Python 爬虫实例

    下面是我写的一个简单爬虫实例 1.定义函数读取html网页的源代码 2.从源代码通过正则表达式挑选出自己需要获取的内容 3.序列中的htm依次写到d盘 #!/usr/bin/python import ...