restful 风格 web api规范

协议:http/https

域名 : http://api.example.com/xxx/xxx

api: 标明api接口服务

xxx: 服务

xxx: 资源

 

版本控制:

一、使用MediaType,即在请求头header中做版本控制,数据格式等控制

想要获取的资源格式

GET /user/123456 HTTP/1.1 

Accept: application/vnd.123456.user-v3+json

获取v3版userid为123456 的用户信息,返回资源格式为json

 

响应的文本格式

HTTP/1.1 200 OK 

Content-Type: application/vnd.123456.user-v3+json 

{"user":  {userId":"123456","name":"张三"} } 

服务端响应v3版userId为123456 的用户信息,返回资源格式为json

严格遵守restful风格,可读性差

二、URI中添加版本信息

 http://api.example.com/v1/xxx/xxx

 缺点:版本的不同会导致同一个资源对应多个uri,后期维护非常麻烦(亲身经历,令人头疼)

三、通过传输固定参数字段 version,比较折中的方法,维护也比较方便

动词(动作):

GET 获取资源

POST 创建资源

PUT 更新资源(客户端提供改变后的完整资源)

PATCH 更新资源(客户端提供改变的属性)

DELETE 删除资源

HEAD 获取资源元数据

OPRATIONS 获取资源属性,哪些是可修改的,属性描述等等

例:GET /user/{userId}    获取用户信息

    POST /user                创建用户

  PUT /user/{userId}    更新项目信息

DELETE /user/{userId}  删除项目信息

安全和幂等

安全性:不会改变资源状态,可以理解为只读的;

幂等性:执行1次和执行N次,对资源状态改变的效果是等价的。

 

安全性

幂等性

GET

POST

×

×

PUT

×

PATCH

×

DELETE

×

HEAD

OPRATIONS

 

 

 

 

 

 

 

 

 

 

 

 

URI规则:

1、uri 标志唯一资源,语义明确

例:用户服务

/user/users/{userId} 

GET /user/users/{userId} 表示查询

PUT /user/users/{userId} 表示更新

单个项目是网络上的资源,一个uri唯一标识,不应该根据操作的不同,版本的不同而改变

 

2、单/复数查询

复数以对应单数名词的复数形式表示

例:

获取用户信息

GET /user/users/{userId}

获取所有用户

GET /user/users

获取某个用户的所有订单信息

GET /user/users/{userId}/orders

获取某个用户的所有某个订单信息

GET /user/users/{userId}/orders/{orderId} 

2、复杂查询

restful 允许url 冗余,允许以 ?name=value的形式过滤资源信息(根据业务的具体情况需要定义一些约定参数,例order排序方式,limit 每页记录 offset 起始记录)

 

表示

备注

过滤条件

?status=1&type=2

资源也可以表示为

/user/users?userId=123456

/user/users/123456

排序

?sort=time,desc

 

投影

?selectlist=userId,name,status

 

分页

?limit=10&offset=1

 

 

 

 

 

 

 

 

 

 

 

例:

获取前10条用户数据

GET /user/users?limit=10

获取第一页用户数据,每页显示10条

GET /user/users?offset=1&limit=10

按时间倒排序获取第一页项目数据,每页显示10条

GET /user/users/?offset=1&limit=10&sort=time,desc

响应数据

响应数据尽可能包含全面信息

{

    //response 状态信息

    "statusCode": 404,

    "statusLine": HTTP/1.1 200 OK,

    "requestData":{"limit":10,"offset":1},

    "responseData":{

        //业务状态

        errorCode:20001

        errorMessage:"签名无效"

        data{

            "paging":{"limit":10,"offset":1,"total":100},

            "users":[{},{},{}]

        }

  }  

}

响应数据可以包含另一个资源的请求信息信息

{

    //response 状态信息

    "statusCode": 200,

    "statusLine": HTTP/1.1 200 OK

    "requestData":{"userId":"123456"},

    "responseData":{

        //业务状态

        errorCode:1

        errorMessage:"成功"

        data{

            "user":["userId":"123456",

         "blod":"http://blod.exmple.com/userId=123456"

        ]

        }

  }  

}

posted @ 2016-12-02 19:37  沐风^_^  阅读(826)  评论(0编辑  收藏  举报