Android中的Retrofit+OkHttp+RxJava缓存架构使用
程序员文章站
2024-03-02 21:50:40
rxjava如何与retrofit结合
先扔出build.gradle文件的内容
dependencies {
compile filetree(dir:...
rxjava如何与retrofit结合
先扔出build.gradle文件的内容
dependencies { compile filetree(dir: 'libs', include: ['*.jar']) testcompile 'junit:junit:4.12' compile 'com.android.support:appcompat-v7:23.2.0' compile 'io.reactivex:rxjava:1.1.0' compile 'io.reactivex:rxandroid:1.1.0' compile 'com.squareup.retrofit2:retrofit:2.0.0-beta4' compile 'com.squareup.retrofit2:converter-gson:2.0.0-beta4' compile 'com.squareup.retrofit2:adapter-rxjava:2.0.0-beta4' compile 'com.google.code.gson:gson:2.6.2' compile 'com.jakewharton:butterknife:7.0.1' }
也就是说本文是基于rxjava1.1.0和retrofit 2.0.0-beta4来进行的。 添加rxandroid是因为rxjava中的线程问题。
下面先搭建一个基本的页面,页面很简单,先来看文件目录结构
activity_main.xml的代码如下:
<?xml version="1.0" encoding="utf-8"?> <relativelayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingbottom="@dimen/activity_vertical_margin" android:paddingleft="@dimen/activity_horizontal_margin" android:paddingright="@dimen/activity_horizontal_margin" android:paddingtop="@dimen/activity_vertical_margin" tools:context=".activity.mainactivity"> <button android:id="@+id/click_me_bn" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignparentbottom="true" android:padding="5dp" android:text="点我" android:textsize="16sp"/> <textview android:id="@+id/result_tv" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_above="@id/click_me_bn" android:text="hello world!" android:textsize="16sp"/> </relativelayout>
mainactivity.java的代码如下:
package com.queen.rxjavaretrofitdemo.activity; import android.os.bundle; import android.support.v7.app.appcompatactivity; import android.widget.button; import android.widget.textview; import com.queen.rxjavaretrofitdemo.r; import butterknife.bind; import butterknife.butterknife; import butterknife.onclick; public class mainactivity extends appcompatactivity { @bind(r.id.click_me_bn) button clickmebn; @bind(r.id.result_tv) textview resulttv; @override protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_main); butterknife.bind(this); } @onclick(r.id.click_me_bn) public void onclick() { getmovie(); } //进行网络请求 private void getmovie(){ } }
注意不要忘记加网络权限
<uses-permission android:name="android.permission.internet"/>
缓存配置
app网络数据的离线缓存实现有很多种办法,例如存进数据库(保存json使用时拿出来解析),存专有文件,或sharedpreference等等,也可以自己实现lrucache和
disklrucache这两种缓存策略构成二级缓存(内存和磁盘)
缓存对于移动端是非常重要的存在:
- 减少请求次数,减小服务器压力.
- 本地数据读取速度更快,让页面不会空白几百毫秒。
- 在无网络的情况下提供数据。
okhttp的缓存设计和浏览器的缓存设计差不多,可以通过添加响应头的形式进行缓存处理。
retrofit是依赖okhttp的一套restful架构的android(java)客户端实现
通过构造retrofit时的.client()方法更改其中的okhttp的实现,从而达到缓存的效果,在这里不介绍retrofit的具体用法。
下面是一个例子实现了有网缓存,无网络只读取缓存
file cachefile = new file(app.getcontext().getexternalcachedir(),"zhibookcache"); cache cache = new cache(cachefile,1024*1024*50); interceptor interceptor = new interceptor() { @override public response intercept(chain chain) throws ioexception { request request = chain.request(); if (!httputils.isnetworkconnected(app.getcontext())) { request = request.newbuilder() .cachecontrol(cachecontrol.force_cache) .build(); } response response = chain.proceed(request); if (httputils.isnetworkconnected(app.getcontext())) { int maxage = 0 * 60; // 有网络时 设置缓存超时时间0个小时 response.newbuilder() .header("cache-control", "public, max-age=" + maxage) .removeheader("pragma")// 清除头信息,因为服务器如果不支持,会返回一些干扰信息,不清除下面无法生效 .build(); } else { // 无网络时,设置超时为4周 int maxstale = 60 * 60 * 24 * 28; response.newbuilder() .header("cache-control", "public, only-if-cached, max-stale=" + maxstale) .removeheader("pragma") .build(); } return response; } }; client = new okhttpclient.builder().cache(cache) .addinterceptor(interceptor) .build(); retrofit = new retrofit.builder() .baseurl(retrofitapi.basic_daily) .addconverterfactory(gsonconverterfactory.create()) .addcalladapterfactory(rxjavacalladapterfactory.create()) .client(client) .build(); retrofitapi = retrofit.create(retrofitapi.class);
之后调用下面代码获取请求后的序列化对象
retrofitapi.getdaily() .subscribeon(schedulers.io()) .observeon(androidschedulers.mainthread()) .subscribe(new observer<dailybean>() { @override public void oncompleted() { } @override public void onerror(throwable e) { log.d(tag,e.getmessage()); } @override public void onnext(dailybean bean) { listener.ongetdailysuccess(bean); } });
最后附上retrofit接口部分
@get("news/latest") observable<dailybean> getdaily();
上一篇: Android仿优酷圆形菜单学习笔记分享