zoukankan      html  css  js  c++  java
  • RESTful API 设计指南

    协议

    使用 HTTP 协议与 API 进行通信。

    域名

    https://api.example.com
    https://example.org/api/
    

    版本

    https://api.example.com/v1/
    

    路径

    在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词,而且所用的名词往往与数据库的表名对应。一般来说,数据库中的表都是同种记录的"集合"(collection),所以API中的名词也应该使用复数。

    https://api.example.com/v1/animals
    https://api.example.com/v1/employees
    

    HTTP动词

    GET(SELECT):从服务器取出资源(一项或多项)。
    POST(CREATE):在服务器新建一个资源。
    PUT(UPDATE):在服务器更新完整的资源。
    PATCH(UPDATE):在服务器更新局部的资源。
    DELETE(DELETE):从服务器删除资源。
    HEAD:获取资源的元数据。
    OPTIONS:获取信息,关于资源的哪些属性是客户端可以改变的。
    
    GET /zoos:列出所有动物园
    POST /zoos:新建一个动物园
    GET /zoos/ID:获取某个指定动物园的信息
    PUT /zoos/ID:更新某个指定动物园的信息(提供该动物园的全部信息)
    PATCH /zoos/ID:更新某个指定动物园的信息(提供该动物园的部分信息)
    DELETE /zoos/ID:删除某个动物园
    GET /zoos/ID/animals:列出某个指定动物园的所有动物
    DELETE /zoos/ID/animals/ID:删除某个指定动物园的指定动物
    
    POST /transaction?from=1&to=2&amount=500
    

    过滤信息

    ?limit=10:指定返回记录的数量
    ?offset=10:指定返回记录的开始位置。
    ?page=2&per_page=100:指定第几页,以及每页的记录数。
    ?sortby=name&order=asc:指定返回结果按照哪个属性排序,以及排序顺序。
    ?animal_type_id:指定筛选条件
    /authors/12?categories=2
    /articles?published=true
    

    返回结果

    GET /collection:返回资源对象的列表(数组)
    GET /collection/resource:返回单个资源对象
    POST /collection:返回新生成的资源对象
    PUT /collection/resource:返回完整的资源对象
    PATCH /collection/resource:返回完整的资源对象
    DELETE /collection/resource:返回一个空文档
    

    其他

    • API的身份认证应该使用 OAuth 2.0 框架。
    • 服务器返回的数据格式,应该尽量使用JSON,避免使用XML。

    参考:

    RESTful API 最佳实践

    RESTful API 设计指南

    理解RESTful架构

  • 相关阅读:
    hbase编码
    kafka常用命令
    国产十大数据库排行榜
    After Titans
    kingbase7获取唯一索引和子分区键的view
    准提道人收孔宣
    MySQL使用全文索引
    instead of触发器实现复杂视图dml和应用逻辑
    中国oracle ace名单
    第六十象 癸亥
  • 原文地址:https://www.cnblogs.com/danhuang/p/12655933.html
Copyright © 2011-2022 走看看