RESTful Android
RESTful Android API 定义
约定
回复中默认包含标头:
Content-Type: application/json;charset=UTF-8异步操作以(*)号标记
大多数异步操作同时只能有一个任务在进行,以上传联系人为例:
客户端每次提交 POST /persons/uploader服务器放弃进行中的上传任务而新建;
客户端可以先访问GET /persons/uploader 获得当前是否有正在上传的任务;
服务器遇到错误的时候会将任务挂起,返回错误原因,客户端可以选择重试或者终止;
客户端接收到任务失败的响应后,如果响应中不包括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
200 OK{total: 100,links:[{rel: "self", href: "/persons?pagesize=10&start=10"},{rel: "pre", href: "/persons?pagesize=10&start=0"},{rel: "next", href: "/persons?pagesize=10&start=20"}],persons:[{link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...},{link: {rel: "self", href: "/person/2"}, id: "2", name: "Lucy"//...}]}
删除所有联系人*
GET /persons/purge
200 OK{link: {rel: "self", href="/persons/purge/0"} //一般不关心上次任务的状态,所以表述中没有捎带其状态}
不使用DELETE /persons, /persons资源仍然可以访问
POST /persons/purge
202 Accpeted{link: {rel: "self", href="/persons/purge/0"}}
GET /persons/purge/0
进行中
200 OK{link: {rel: "self", href="/persons/purge/0"},state: "pending",percent: "30"}
成功
303 See OtherLocation: "/persons"{link: {rel: "self", href="/persons/purge/0"},state: "done"}
失败
200 OK{links:[{rel: "self", href="/persons/purge/0"},{rel: "retry", href="/persons/purge/0"}]state: "failed",reason: "XXX",}
重试
PUT /persons/purge/0
200 OK
终止
DELETE /persons/purge/0
200 OK
上传联系人*
GET /persons/uploader
200 OK{link: {rel: "self", href="/persons/uploader/0"}}}
POST /persons/uploader
[
{name: "Jack"},
{name: "Lucy"},
{name: "Lily"}
]
202 Accepted{link: {rel: "self", href="/persons/uploader/0"}}}
GET /persons/uploader
进行中
200 OK{link: {rel: "self", href="/persons/uploader/0"},state: "pending",percent: "30"}
成功
303 See OtherLocation: "/persons"{link: {rel: "self", href="/persons/uploader/0"},state: "done"}
失败
200 OK{links:[{rel: "self", href="/persons/uploader/0"},{rel: "retry", href="/persons/uploader/0"}]state: "failed",reason: "XXX"}
重试
PUT /persons/uploader/0
200 OK
终止
DELETE /persons/uploader/0
200 OK
获取联系人信息
GET /person/1
200 OK{link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...}
新建联系人
POST /persons
{
name: "Jack"//...
}
201 Created{link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...}
编辑联系人
PUT /person/1
{
name: "Jack"//...
}
200 OK{link: {rel: "self", href: "/person/1"}, id: "1", name: "Jack"//...}
删除联系人
DELETE /person/1
200{name: "Jack"//...}
参考
RESTful Android的更多相关文章
- Android教程收集贴
Loader & REST Rest Loader Tutorial [github源码] [源码演示] [github作者主页] Twitter Timeline Sample for An ...
- 用Jersey为Android客户端开发Restful Web Service
平时在做Android客户端的时候经常要与服务器之间通信,客户端通过服务端提供的接口获取数据,然后再展示在客户端的界面上,作为Android开发者,我们平时更多的是关注客户端的开发,而对服务端开发的关 ...
- SSM整合 完美支持RESTful(Jsp和客户端<android ios...>)
一 RESTful简介 RESTful是一种网络应用程序的设计风格和开发方式 它结构清晰 符合标准 易于理解 扩展方便 REST 即Representational State Transfer的缩写 ...
- Android,适合Restful网络请求封装
借助volley.Gson类库. 优点 网络请求集中处理,返回值直接为预期的对象,不需要手动反序列,提高效率,使用时建立好model类即可. 使用效果 DataProess.Request(true, ...
- 2015最流行的Android组件、工具、框架大全
Android 是目前最流行的移动操作系统之一. 随着新版本的不断发布, Android的功能也日益强大, 涌现了很多流行的应用程序, 也催生了一大批的优秀的组件. 本文试图将目前流行的组件收集起来以 ...
- [转] Android优秀开源项目
Android经典的开源项目其实非常多,但是国内的博客总是拿着N年前的一篇复制来复制去,实在是不利于新手学习.今天爬爬把自己熟悉的一些开源项目整理起来,希望能对Android开发同学们有所帮助.另外, ...
- Android开发笔记之《远程控制(MQTT|mosquitto) && (ProtocalBuffer | GRPC)》
Android推送方案分析(MQTT/XMPP/GCM): http://www.open-open.com/lib/view/open1410848945601.htmlMQTT官网: http:/ ...
- Android高手速成--第二部分 工具库
主要包括那些不错的开发库,包括依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本向低版本兼容.多媒体相关及其他. 一.依赖注入DI 通过依赖注入减少Vie ...
- Android 多媒体视频播放一( 多媒体理解与经验分享)
前言 说到android的多媒体,一把辛酸一把泪,当初听说会多媒体的比较牛掰,公司也有需求,于是乎我也积极的加入研究android多媒体的行列,记得以前刚接触的时候,最开始还是比较头大的,主要是但是很 ...
随机推荐
- SVN常见问题I
TortoiseSVN ->Settings 把权限给清空,不让用户A的权限再保留在里面 右键->SVN Checkout 之后需要在A账户和B账户之间来回切换
- Median(二分+二分)
Median http://poj.org/problem?id=3579 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1 ...
- Django的模板继承
来看一个例子 我们有一个订单的页面和购物车的页面,比如下面的截图,我的购物车的页面和订单的页面只有圆圈中的截图的内容不一样 所以我们的订单的html页面和购物车的html业务的html几乎都是一致的 ...
- 测试SQL
create database testDB create table users( id int primary key identity(1,1), uname nvarchar(20 ...
- OpenStack的架构详解(转)
OpenStack既是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集.其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云,也为大云.小云提供可扩展的.灵活的 ...
- php中的declare
<?php // 事件的回调函数 function func_tick() { echo "call...\r\n"; } // 注册事件的回调函数 register_tic ...
- Java8 改进的匿名内部类:
1.匿名内部类适合创建那种只需要一次使用的类 2.匿名内部类定义格式: new 实现接口() | 父类构造器(实参列表){ //匿名内部类类体部分 } 3.从上面定义格式可以看出,匿名内部类必须实现一 ...
- OSGi 系列(十八)之 基于注解的 Blueprint
OSGi 系列(十八)之 基于注解的 Blueprint 1. 注解实现 blueprint 第一步:bundle 添加 Bundle-Blueprint-Annotation <plugin& ...
- 情感分析snownlp包部分核心代码理解
snownlps是用Python写的个中文情感分析的包,自带了中文正负情感的训练集,主要是评论的语料库.使用的是朴素贝叶斯原理来训练和预测数据.主要看了一下这个包的几个主要的核心代码,看的过程作了一些 ...
- hdu-1063(大数)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1063 思路:1.大数乘法模板 2.考虑小数点的位置 3.乘法前后判断前后道0 参考文章:https:/ ...