更新到Retrofit2的一些技巧

作者 小武站台 关注

2016.02.22 22:13* 字数 1348 阅读 1621评论 0喜欢 5赞赏 1

原文链接:Tips on updating to Retrofit 2
ps:其实我老早就更新到Retrofit2了 但是不同的beta版目前改变还是挺大的,如果你在用的话 ,要时刻跟进并查看它的changelog.该文章还是比较倾向于1.9升级2.0 但是就像前面说的 beta2到beta4改变也是非常大的 所以同样可以参考用于备忘

Retrofit2.0已经公开发布几个月了,但是现在依然是beta版,一些开发者已经开始从之前的版本进行升级,虽然官方已经提供了文档,文章或博客让你了解最新版的相关信息,但是在StackOverflow还是可以看到一些提问关于在升级版本的过程中怎么处理常见功能像logging打印日志,添加request parameter或者使用JSON对象等,所以在这篇文章中,我会告诉你关于这些问题的一些技巧。

写文章时,Retrofit的版本是v2.0.0-beta4.

新的group id

第一个你会注意到的改变是新的group id,变成了com.squareup.retrofit2,所以新的依赖声明是:

compile 'com.squareup.retrofit2:retrofit:2.0.0-beta4'

新的包名

主包名已经改成了

package retrofit2;

这意味的你需要更改所有关于Retrofit的import,此外,如果你还有其他涉及到包名的代码或任务,记得也要更新他们。

proguard 配置

因为新包名,如果你开启了混淆代码,第一件要做的事就是更新配置文件的规则,它们可以在官方网站找到:

-dontwarn retrofit2.**
-keep class retrofit2.** { *; }
-keepattributes Signature
-keepattributes Exceptions

okhttp

okhttp现在Retrofit2内置的默认依赖,实际上,查看Retrofit2的pom文件(maven的依赖配置文件),会发现下面的依赖:

<dependency>
<groupId>com.squareup.okhttp3</groupId>
<artifactId>okhttp</artifactId>
</dependency>

如果你不需要用一个特殊版本的okhttp或者其他http client,你不用做任何事情。

生成服务接口实现

service interface implementation generation

你会立即注意到的另外一件事是你的生成服务接口实现的代码没法编译了。

下面是Retrofit的典型代码:

RestAdapter restAdapter = new RestAdapter.Builder()
.setEndpoint("https://api.github.com")
.build();
GitHubService service = restAdapter.create(GitHubService.class);

在Retrofit2,会变成:

Retrofit retrofit = new Retrofit.Builder()
.baseUrl("https://api.github.com")
.build();
GitHubService service = retrofit.create(GitHubService.class);

你可以看到,依然是build模式,但是涉及的方法和类已经变了。

logging

在开发中打印网络请求和返回结果是非常重要的,如果你在Retrofit中启用了这个功能,你会发现实现该功能的方法已经不可用了。

setLogLevel(RestAdapter.LogLevel.FULL)

那是因为你现在必须依靠okhttp提供的日志系统,HttpLoggingInterceptor.

首先声明一个新的依赖,因为它不是okhttp的一部分所以要另外添加依赖:

compile 'com.squareup.okhttp3:logging-interceptor:3.1.2'

然后,创建一个interceptor实例:

HttpLoggingInterceptor httpLoggingInterceptor = new HttpLoggingInterceptor();
httpLoggingInterceptor.setLevel(HttpLoggingInterceptor.Level.BODY);

再然后,添加到OkHttp client实例中:

OkHttpClient okHttpClient = new OkHttpClient.Builder().addInterceptor(httpLoggingInterceptor).build();

最后,把client设置到service interface实现中:

Retrofit retrofit = new Retrofit.Builder()
.client(okHttpClient)
.baseUrl(MovieDbApi.END_POINT)
.build();
movieDbApi = retrofit.create(MovieDbApi.class);

ps:其实这个log并不是很好用,最好自己参考源码自己自定义一个,分分钟就搞定了。

gson converter

By default, Retrofit can only deserialize HTTP bodies into OkHttp’s ResponseBody type and it can only accept its RequestBodytype for @Body.

这意味得用来支持其他types的converter必须在创建服务接口时进行设置

为了让JSON和Java对象相互转换,我们需要设置一个GSON转换器

首先,需要一个新的依赖:

compile 'com.squareup.retrofit2:converter-gson:2.0.0-beta4'

然后设置converter factory:

Retrofit retrofit = new Retrofit.Builder()
.client(okHttpClient)
.baseUrl(MovieDbApi.END_POINT)
.addConverterFactory(GsonConverterFactory.create())
.build();
movieDbApi = retrofit.create(MovieDbApi.class);

完整的可用converters可以查看官方文档

interceptor

Retrofit另外一个有用的功能是可以拦截http请求进行监控,重写或重试

一个典型应用场景是所有http请求需要加上api key,在Retrofit2之前,可以通过RequestInterceptor实现:

final RequestInterceptor authorizationInterceptor = new RequestInterceptor() {
@Override
public void intercept(RequestInterceptor.RequestFacade request) {
request.addQueryParam(MovieDbApi.PARAM_API_KEY, "YOUR_API_KEY");
}
};

然后

RestAdapter restAdapter = new RestAdapter.Builder()
.setEndpoint(MovieDbApi.END_POINT)
.setRequestInterceptor(authorizationInterceptor)
.build();
movieDbApi = restAdapter.create(MovieDbApi.class);

在Retrofit2中已经不再有效了,因为你现在必须依靠OKHttp interceptors.

你可以直接在OKHttp client实例化时进行设置:

OkHttpClient okHttpClient = new OkHttpClient.Builder().addInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request();
HttpUrl url = request.url().newBuilder().addQueryParameter(
MovieDbApi.PARAM_API_KEY, BuildConfig.MOVIE_DB_API_KEY).build();
request = request.newBuilder().url(url).build();
return chain.proceed(request);
}
}).build();

然后像前面那样设置client:

Retrofit retrofit = new Retrofit.Builder()
.client(okHttpClient)
.baseUrl(MovieDbApi.END_POINT)
.build();
movieDbApi = retrofit.create(MovieDbApi.class);

RxJava observable

如果你正在使用RxJava,你会注意到Retrofit2 interfaces已经不支持Observable了,实际上,Call模式被用于标准的http请求。

当然你可以用你自己的类型,提供你自己的CallAdapter实现,但是幸运的是已经有可用的了,RxJavaCallAdapterFactory.简单说,它把Call转换成Observable.

首先,添加依赖:

com.squareup.retrofit2:adapter-rxjava:2.0.0-beta4

然后,用addCallAdapterFactory进行设置:

Retrofit retrofit = new Retrofit.Builder()
.client(okHttpClient)
.baseUrl(MovieDbApi.END_POINT)
.addConverterFactory(GsonConverterFactory.create())
.addCallAdapterFactory(RxJavaCallAdapterFactory.create())
.build();
movieDbApi = retrofit.create(MovieDbApi.class);

 

(转载)更新到Retrofit2的一些技巧的更多相关文章

  1. ( 译、持续更新 ) JavaScript 上分小技巧(四)

    后续如有内容,本篇将会照常更新并排满15个知识点,以下是其他几篇译文的地址: 第一篇地址:( 译.持续更新 ) JavaScript 上分小技巧(一) 第二篇地址:( 译.持续更新 ) JavaScr ...

  2. ( 译、持续更新 ) JavaScript 上分小技巧(三)

    最近家里杂事较多,自学时间实在少的可怜,所以都在空闲时间看看老外写的内容,学习之外顺便翻译分享~等学习的时间充足些再写写自己的一些学习内容和知识点分析(最近有在接触的:复习(C#,SQL).(学习)T ...

  3. ( 译、持续更新 ) JavaScript 上分小技巧(二)

    考虑到文章过长,不便于阅读,这里分出第二篇,如有后续,每15个知识点分为一篇... 第一篇地址:( 译.持续更新 ) JavaScript 上分小技巧(一) 第三篇地址:( 译.持续更新 ) Java ...

  4. ( 译、持续更新 ) JavaScript 上分小技巧(一)

    感谢好友破狼提供的这篇好文章,也感谢写这些知识点的作者们和将他们整理到一起的作者.这是github上的一篇文章,在这里本兽也就只做翻译,由于本兽英语水平和编程能力都不咋地,如有不好的地方也请多理解体谅 ...

  5. 在生产环境中安全执行更新删除SQL脚本的技巧

    今天在生产环境上解决问题,由于广发银行的管理制度是开发公司是不允许确生产环境的,所以我们只能把要更新的语句发给运营中心,由运营中心的投产人员执行,我们则在旁边看着:在他执行的时候发现了一个很有趣的技巧 ...

  6. 一些有意思的面试题(持续更新) .C语言编程技巧札记

    一些有意思的面试题(持续更新) http://blog.csdn.net/wangyuling1234567890/article/details/38565239 C语言编程技巧札记 http:// ...

  7. (转载) Android Studio你不知道的调试技巧

    Android Studio你不知道的调试技巧 标签: android studio 2015-12-29 16:05 2514人阅读 评论(0) 收藏 举报  分类: android(74)    ...

  8. (转载) TextView使用一些小技巧

    TextView使用一些小技巧 标签: textviewandroid开发 2015-10-09 16:13 810人阅读 评论(0) 收藏 举报  分类: Android(20)  本文主要讲一些T ...

  9. Datagrip 快捷键和常用插件持续更新一集一些使用技巧

    快捷键 Ctrl+Enter:执行选中的SQL语句 Ctrl+Shift+左右箭头:调整列宽度(选中行,可以调整所有列的宽度) Ctrl+N / 双击Shift :全局搜索,点击可直接进入表 Ctrl ...

随机推荐

  1. Node.js 常用Mongoose方法

    Node.js 手册查询-Mongoose 方法 一.Schema 一种以文件形式存储的数据库模型骨架,无法直接通往数据库端,也就是说它不具备对数据库的操作能力.可以说是数据属性模型(传统意义的表结构 ...

  2. javaee字符文件的复制

    package Zy; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.FileWrit ...

  3. 【转载】Java IO 转换流 字节转字符流

    字节流输入字节流:---------| InputStream 所有输入字节流的基类. 抽象类.------------| FileInputStream 读取文件的输入字节流.----------- ...

  4. Day4 循环结构

    for-in循环 如果明确的知道循环执行的次数或者是要对一个容器进行迭代(后面会讲到),那么我们推荐使用for-in循环,例如下面代码中计算$\sum_{n=1}^{100}n$. range函数用法 ...

  5. [luogu1155 NOIP2008] 双栈排序 (二分图染色)

    传送门 Description Input 第一行是一个整数 n . 第二行有 n 个用空格隔开的正整数,构成一个 1−n 的排列. Output 共一行,如果输入的排列不是"可双栈排序排列 ...

  6. 【ownCloud】添加信任域

    如果在安装ownCloud后,更换了访问方式,比如刚开始是http://127.0.0.1/owncloud,变成了http://1.1.1.1/owncloud,那么在访问时可能得到这样的页面: 您 ...

  7. django数据库设置为MySQL

    django默认使用sqlite,然后想使用MySQL数据库 在项目的setting文件中找到 DATABASES = { 'default': { 'ENGINE': 'django.db.back ...

  8. Codeforces 902D/901B - GCD of Polynomials

    传送门:http://codeforces.com/contest/902/problem/D 本题是一个数学问题——多项式整除. 对于两个整数a.b,求最大公约数gcd(a,b)的辗转相除法的函数如 ...

  9. ecshop3 调用指定分类下推荐/热卖/新品商品,可指定调用数量

    第一步:--------------------------------------------------------------------------------------/** * 取指定分 ...

  10. 【codeforces 798C】Mike and gcd problem

    [题目链接]:http://codeforces.com/contest/798/problem/C [题意] 给你n个数字; 要求你进行若干次操作; 每次操作对第i和第i+1个位置的数字进行; 将 ...